xref: /freebsd/sys/cam/scsi/scsi_ses.h (revision 924226fba12cc9a228c73b956e1b7fa24c60b055)
1 /* $FreeBSD$ */
2 /*-
3  * SPDX-License-Identifier: (BSD-2-Clause-FreeBSD OR GPL-2.0)
4  *
5  * Copyright (c) 2000 by Matthew Jacob
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  * 1. Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions, and the following disclaimer,
13  *    without modification, immediately at the beginning of the file.
14  * 2. The name of the author may not be used to endorse or promote products
15  *    derived from this software without specific prior written permission.
16  *
17  * Alternatively, this software may be distributed under the terms of the
18  * the GNU Public License ("GPL").
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
24  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30  * SUCH DAMAGE.
31  *
32  */
33 
34 #ifndef	_SCSI_SES_H_
35 #define	_SCSI_SES_H_
36 
37 #include <cam/scsi/scsi_all.h>
38 
39 /*========================== Field Extraction Macros =========================*/
40 #define MK_ENUM(S, F, SUFFIX) S ## _ ## F ## SUFFIX
41 
42 #define GEN_GETTER(LS, US, LF, UF)					    \
43 static inline int							    \
44 LS ## _get_ ## LF(struct LS *elem) {					    \
45 	return ((elem->bytes[MK_ENUM(US,UF,_BYTE)] & MK_ENUM(US,UF,_MASK))  \
46 	     >> MK_ENUM(US,UF,_SHIFT));					    \
47 }
48 
49 #define GEN_SETTER(LS, US, LF, UF)					    \
50 static inline void							    \
51 LS ## _set_ ## LF(struct LS *elem, int val) {				    \
52 	elem->bytes[MK_ENUM(US,UF,_BYTE)] &= ~MK_ENUM(US,UF,_MASK);	    \
53 	elem->bytes[MK_ENUM(US,UF,_BYTE)] |=				    \
54 	    (val << MK_ENUM(US,UF,_SHIFT)) & MK_ENUM(US,UF,_MASK);	    \
55 }
56 
57 #define GEN_HDR_GETTER(LS, US, LF, UF)					    \
58 static inline int							    \
59 LS ## _get_ ## LF(struct LS *page) {					    \
60 	return ((page->hdr.page_specific_flags & MK_ENUM(US,UF,_MASK))	    \
61 	     >> MK_ENUM(US,UF,_SHIFT));					    \
62 }
63 
64 #define GEN_HDR_SETTER(LS, US, LF, UF)					    \
65 static inline void							    \
66 LS ## _set_ ## LF(struct LS *page, int val) {				    \
67 	page->hdr.page_specific_flags &= ~MK_ENUM(US,UF,_MASK);		    \
68 	page->hdr.page_specific_flags |=				    \
69 	    (val << MK_ENUM(US,UF,_SHIFT)) & MK_ENUM(US,UF,_MASK);	    \
70 }
71 
72 #define GEN_ACCESSORS(LS, US, LF, UF)					    \
73 GEN_GETTER(LS, US, LF, UF)						    \
74 GEN_SETTER(LS, US, LF, UF)
75 
76 #define GEN_HDR_ACCESSORS(LS, US, LF, UF)				    \
77 GEN_HDR_GETTER(LS, US, LF, UF)						    \
78 GEN_HDR_SETTER(LS, US, LF, UF)
79 
80 /*===============  Common SCSI ENC Diagnostic Page Structures ===============*/
81 struct ses_page_hdr {
82 	uint8_t page_code;
83 	uint8_t page_specific_flags;
84 	uint8_t length[2];
85 	uint8_t gen_code[4];
86 };
87 
88 static inline size_t
89 ses_page_length(const struct ses_page_hdr *hdr)
90 {
91 	/*
92 	 * The page length as received only accounts for bytes that
93 	 * follow the length field, namely starting with the generation
94 	 * code field.
95 	 */
96 	return (scsi_2btoul(hdr->length)
97 	      + offsetof(struct ses_page_hdr, gen_code));
98 }
99 
100 /*============= SCSI ENC Configuration Diagnostic Page Structures ============*/
101 struct ses_enc_desc {
102 	uint8_t byte0;
103 	/*
104 	 * reserved0	: 1,
105 	 * rel_id	: 3,	relative enclosure process id
106 	 * reserved1	: 1,
107 	 * num_procs	: 3;	number of enclosure procesenc
108 	 */
109 	uint8_t	subenc_id;	/* Sub-enclosure Identifier */
110 	uint8_t	num_types;	/* # of supported types */
111 	uint8_t	length;		/* Enclosure Descriptor Length */
112 	uint8_t	logical_id[8];	/* formerly wwn */
113 	uint8_t	vendor_id[8];
114 	uint8_t	product_id[16];
115 	uint8_t	product_rev[4];
116 	uint8_t vendor_bytes[];
117 };
118 
119 static inline uint8_t *
120 ses_enc_desc_last_byte(struct ses_enc_desc *encdesc)
121 {
122 	return (&encdesc->length + encdesc->length);
123 }
124 
125 static inline struct ses_enc_desc *
126 ses_enc_desc_next(struct ses_enc_desc *encdesc)
127 {
128 	return ((struct ses_enc_desc *)(ses_enc_desc_last_byte(encdesc) + 1));
129 }
130 
131 static inline int
132 ses_enc_desc_is_complete(struct ses_enc_desc *encdesc, uint8_t *last_buf_byte)
133 {
134 	return (&encdesc->length <= last_buf_byte
135 	     && ses_enc_desc_last_byte(encdesc) <= last_buf_byte);
136 }
137 
138 struct ses_elm_type_desc {
139 	uint8_t	etype_elm_type;	/* type of element */
140 	uint8_t	etype_maxelt;	/* maximum supported */
141 	uint8_t	etype_subenc;	/* in sub-enclosure #n */
142 	uint8_t	etype_txt_len;	/* Type Descriptor Text Length */
143 };
144 
145 struct ses_cfg_page {
146 	struct ses_page_hdr hdr;
147 	struct ses_enc_desc subencs[];
148 	/* type descriptors */
149 	/* type text */
150 };
151 
152 static inline int
153 ses_cfg_page_get_num_subenc(struct ses_cfg_page *page)
154 {
155 	return (page->hdr.page_specific_flags + 1);
156 }
157 
158 /*================ SCSI SES Control Diagnostic Page Structures ==============*/
159 struct ses_ctrl_common {
160 	uint8_t bytes[1];
161 };
162 
163 enum ses_ctrl_common_field_data {
164 	SES_CTRL_COMMON_SELECT_BYTE		= 0,
165 	SES_CTRL_COMMON_SELECT_MASK		= 0x80,
166 	SES_CTRL_COMMON_SELECT_SHIFT		= 7,
167 
168 	SES_CTRL_COMMON_PRDFAIL_BYTE		= 0,
169 	SES_CTRL_COMMON_PRDFAIL_MASK		= 0x40,
170 	SES_CTRL_COMMON_PRDFAIL_SHIFT		= 6,
171 
172 	SES_CTRL_COMMON_DISABLE_BYTE		= 0,
173 	SES_CTRL_COMMON_DISABLE_MASK		= 0x20,
174 	SES_CTRL_COMMON_DISABLE_SHIFT		= 5,
175 
176 	SES_CTRL_COMMON_RST_SWAP_BYTE		= 0,
177 	SES_CTRL_COMMON_RST_SWAP_MASK		= 0x10,
178 	SES_CTRL_COMMON_RST_SWAP_SHIFT		= 4
179 };
180 
181 #define GEN_SES_CTRL_COMMON_ACCESSORS(LCASE, UCASE) \
182     GEN_ACCESSORS(ses_ctrl_common, SES_CTRL_COMMON, LCASE, UCASE)
183 GEN_SES_CTRL_COMMON_ACCESSORS(select,   SELECT)
184 GEN_SES_CTRL_COMMON_ACCESSORS(prdfail,  PRDFAIL)
185 GEN_SES_CTRL_COMMON_ACCESSORS(disable,  DISABLE)
186 GEN_SES_CTRL_COMMON_ACCESSORS(rst_swap, RST_SWAP)
187 #undef GEN_SES_CTRL_COMMON_ACCESSORS
188 
189 /*------------------------ Device Slot Control Element ----------------------*/
190 struct ses_ctrl_dev_slot {
191 	struct ses_ctrl_common common;
192 	uint8_t bytes[3];
193 };
194 
195 enum ses_ctrl_dev_slot_field_data {
196 	SES_CTRL_DEV_SLOT_RQST_ACTIVE_BYTE	= 1,
197 	SES_CTRL_DEV_SLOT_RQST_ACTIVE_MASK	= 0x80,
198 	SES_CTRL_DEV_SLOT_RQST_ACTIVE_SHIFT	= 7,
199 
200 	SES_CTRL_DEV_SLOT_DO_NOT_REMOVE_BYTE	= 1,
201 	SES_CTRL_DEV_SLOT_DO_NOT_REMOVE_MASK	= 0x40,
202 	SES_CTRL_DEV_SLOT_DO_NOT_REMOVE_SHIFT	= 6,
203 
204 	SES_CTRL_DEV_SLOT_RQST_MISSING_BYTE	= 1,
205 	SES_CTRL_DEV_SLOT_RQST_MISSING_MASK	= 0x10,
206 	SES_CTRL_DEV_SLOT_RQST_MISSING_SHIFT	= 4,
207 
208 	SES_CTRL_DEV_SLOT_RQST_INSERT_BYTE	= 1,
209 	SES_CTRL_DEV_SLOT_RQST_INSERT_MASK	= 0x08,
210 	SES_CTRL_DEV_SLOT_RQST_INSERT_SHIFT	= 3,
211 
212 	SES_CTRL_DEV_SLOT_RQST_REMOVE_BYTE	= 1,
213 	SES_CTRL_DEV_SLOT_RQST_REMOVE_MASK	= 0x04,
214 	SES_CTRL_DEV_SLOT_RQST_REMOVE_SHIFT	= 2,
215 
216 	SES_CTRL_DEV_SLOT_RQST_IDENT_BYTE	= 1,
217 	SES_CTRL_DEV_SLOT_RQST_IDENT_MASK	= 0x02,
218 	SES_CTRL_DEV_SLOT_RQST_IDENT_SHIFT	= 1,
219 
220 	SES_CTRL_DEV_SLOT_RQST_FAULT_BYTE	= 2,
221 	SES_CTRL_DEV_SLOT_RQST_FAULT_MASK	= 0x20,
222 	SES_CTRL_DEV_SLOT_RQST_FAULT_SHIFT	= 5,
223 
224 	SES_CTRL_DEV_SLOT_DEVICE_OFF_BYTE	= 2,
225 	SES_CTRL_DEV_SLOT_DEVICE_OFF_MASK	= 0x10,
226 	SES_CTRL_DEV_SLOT_DEVICE_OFF_SHIFT	= 4,
227 
228 	SES_CTRL_DEV_SLOT_ENABLE_BYP_A_BYTE	= 2,
229 	SES_CTRL_DEV_SLOT_ENABLE_BYP_A_MASK	= 0x08,
230 	SES_CTRL_DEV_SLOT_ENABLE_BYP_A_SHIFT	= 3,
231 
232 	SES_CTRL_DEV_SLOT_ENABLE_BYP_B_BYTE	= 2,
233 	SES_CTRL_DEV_SLOT_ENABLE_BYP_B_MASK	= 0x04,
234 	SES_CTRL_DEV_SLOT_ENABLE_BYP_B_SHIFT	= 2
235 };
236 #define GEN_SES_CTRL_DEV_SLOT_ACCESSORS(LCASE, UCASE) \
237     GEN_ACCESSORS(ses_ctrl_dev_slot, SES_CTRL_DEV_SLOT, LCASE, UCASE)
238 
239 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_active,   RQST_ACTIVE)
240 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(do_not_remove, DO_NOT_REMOVE)
241 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_missing,  RQST_MISSING)
242 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_insert,   RQST_INSERT)
243 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_remove,   RQST_REMOVE)
244 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_ident,    RQST_IDENT)
245 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(rqst_fault,    RQST_FAULT)
246 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(device_off,    DEVICE_OFF)
247 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(enable_byp_a,  ENABLE_BYP_A)
248 GEN_SES_CTRL_DEV_SLOT_ACCESSORS(enable_byp_b,  ENABLE_BYP_B)
249 #undef GEN_SES_CTRL_DEV_SLOT_ACCESSORS
250 
251 /*--------------------- Array Device Slot Control Element --------------------*/
252 struct ses_ctrl_array_dev_slot {
253 	struct ses_ctrl_common common;
254 	uint8_t bytes[3];
255 };
256 
257 enum ses_ctrl_array_dev_slot_field_data {
258 	SES_CTRL_ARRAY_DEV_SLOT_RQST_OK_BYTE			= 0,
259 	SES_CTRL_ARRAY_DEV_SLOT_RQST_OK_MASK			= 0x80,
260 	SES_CTRL_ARRAY_DEV_SLOT_RQST_OK_SHIFT			= 7,
261 
262 	SES_CTRL_ARRAY_DEV_SLOT_RQST_RSVD_DEVICE_BYTE		= 0,
263 	SES_CTRL_ARRAY_DEV_SLOT_RQST_RSVD_DEVICE_MASK		= 0x40,
264 	SES_CTRL_ARRAY_DEV_SLOT_RQST_RSVD_DEVICE_SHIFT		= 6,
265 
266 	SES_CTRL_ARRAY_DEV_SLOT_RQST_HOT_SPARE_BYTE		= 0,
267 	SES_CTRL_ARRAY_DEV_SLOT_RQST_HOT_SPARE_MASK		= 0x20,
268 	SES_CTRL_ARRAY_DEV_SLOT_RQST_HOT_SPARE_SHIFT		= 5,
269 
270 	SES_CTRL_ARRAY_DEV_SLOT_RQST_CONS_CHECK_BYTE		= 0,
271 	SES_CTRL_ARRAY_DEV_SLOT_RQST_CONS_CHECK_MASK		= 0x10,
272 	SES_CTRL_ARRAY_DEV_SLOT_RQST_CONS_CHECK_SHIFT		= 4,
273 
274 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_CRIT_ARRAY_BYTE		= 0,
275 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_CRIT_ARRAY_MASK		= 0x08,
276 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_CRIT_ARRAY_SHIFT	= 3,
277 
278 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_FAILED_ARRAY_BYTE	= 0,
279 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_FAILED_ARRAY_MASK	= 0x04,
280 	SES_CTRL_ARRAY_DEV_SLOT_RQST_IN_FAILED_ARRAY_SHIFT	= 2,
281 
282 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_BYTE		= 0,
283 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_MASK		= 0x02,
284 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_SHIFT	= 1,
285 
286 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_ABORT_BYTE	= 0,
287 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_ABORT_MASK	= 0x01,
288 	SES_CTRL_ARRAY_DEV_SLOT_RQST_REBUILD_REMAP_ABORT_SHIFT	= 0
289 
290 	/*
291 	 * The remaining fields are identical to the device
292 	 * slot element type.  Access them through the device slot
293 	 * element type and its accessors.
294 	 */
295 };
296 #define GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(LCASE, UCASE)		\
297     GEN_ACCESSORS(ses_ctrl_array_dev_slot, SES_CTRL_ARRAY_DEV_SLOT,	\
298 		  LCASE, UCASE)
299 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_ok,             RQST_OK)
300 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_rsvd_device,    RQST_RSVD_DEVICE)
301 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_hot_spare,      RQST_HOT_SPARE)
302 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_cons_check,     RQST_CONS_CHECK)
303 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_in_crit_array,  RQST_IN_CRIT_ARRAY)
304 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_in_failed_array,
305 				      RQST_IN_FAILED_ARRAY)
306 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_rebuild_remap,  RQST_REBUILD_REMAP)
307 GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS(rqst_rebuild_remap_abort,
308 				      RQST_REBUILD_REMAP_ABORT)
309 #undef GEN_SES_CTRL_ARRAY_DEV_SLOT_ACCESSORS
310 
311 /*----------------------- Power Supply Control Element -----------------------*/
312 struct ses_ctrl_power_supply {
313 	struct ses_ctrl_common common;
314 	uint8_t bytes[3];
315 };
316 
317 enum ses_ctrl_power_supply_field_data {
318 	SES_CTRL_POWER_SUPPLY_RQST_IDENT_BYTE	= 0,
319 	SES_CTRL_POWER_SUPPLY_RQST_IDENT_MASK	= 0x80,
320 	SES_CTRL_POWER_SUPPLY_RQST_IDENT_SHIFT	= 7,
321 
322 	SES_CTRL_POWER_SUPPLY_RQST_FAIL_BYTE	= 2,
323 	SES_CTRL_POWER_SUPPLY_RQST_FAIL_MASK	= 0x40,
324 	SES_CTRL_POWER_SUPPLY_RQST_FAIL_SHIFT	= 6,
325 
326 	SES_CTRL_POWER_SUPPLY_RQST_ON_BYTE	= 2,
327 	SES_CTRL_POWER_SUPPLY_RQST_ON_MASK	= 0x20,
328 	SES_CTRL_POWER_SUPPLY_RQST_ON_SHIFT	= 5
329 };
330 
331 #define GEN_SES_CTRL_POWER_SUPPLY_ACCESSORS(LCASE, UCASE)	\
332     GEN_ACCESSORS(ses_ctrl_power_supply, SES_CTRL_POWER_SUPPLY, LCASE, UCASE)
333 GEN_SES_CTRL_POWER_SUPPLY_ACCESSORS(rqst_ident, RQST_IDENT)
334 GEN_SES_CTRL_POWER_SUPPLY_ACCESSORS(rqst_fail,  RQST_FAIL)
335 GEN_SES_CTRL_POWER_SUPPLY_ACCESSORS(rqst_on,    RQST_ON)
336 #undef GEN_SES_CTRL_POWER_SUPPLY_ACCESSORS
337 
338 /*-------------------------- Cooling Control Element -------------------------*/
339 struct ses_ctrl_cooling {
340 	struct ses_ctrl_common common;
341 	uint8_t bytes[3];
342 };
343 
344 enum ses_ctrl_cooling_field_data {
345 	SES_CTRL_COOLING_RQST_IDENT_BYTE		= 0,
346 	SES_CTRL_COOLING_RQST_IDENT_MASK		= 0x80,
347 	SES_CTRL_COOLING_RQST_IDENT_SHIFT		= 7,
348 
349 	SES_CTRL_COOLING_RQST_FAIL_BYTE			= 2,
350 	SES_CTRL_COOLING_RQST_FAIL_MASK			= 0x40,
351 	SES_CTRL_COOLING_RQST_FAIL_SHIFT		= 6,
352 
353 	SES_CTRL_COOLING_RQST_ON_BYTE			= 2,
354 	SES_CTRL_COOLING_RQST_ON_MASK			= 0x20,
355 	SES_CTRL_COOLING_RQST_ON_SHIFT			= 5,
356 
357 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_BYTE		= 2,
358 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_MASK		= 0x07,
359 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_SHIFT	= 2,
360 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_UNCHANGED	= 0x00,
361 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_LOWEST	= 0x01,
362 	SES_CTRL_COOLING_RQSTED_SPEED_CODE_HIGHEST	= 0x07
363 };
364 
365 #define GEN_SES_CTRL_COOLING_ACCESSORS(LCASE, UCASE)	\
366     GEN_ACCESSORS(ses_ctrl_cooling, SES_CTRL_COOLING, LCASE, UCASE)
367 GEN_SES_CTRL_COOLING_ACCESSORS(rqst_ident,        RQST_IDENT)
368 GEN_SES_CTRL_COOLING_ACCESSORS(rqst_fail,         RQST_FAIL)
369 GEN_SES_CTRL_COOLING_ACCESSORS(rqst_on,           RQST_ON)
370 GEN_SES_CTRL_COOLING_ACCESSORS(rqsted_speed_code, RQSTED_SPEED_CODE)
371 #undef GEN_SES_CTRL_COOLING_ACCESSORS
372 
373 /*-------------------- Temperature Sensor Control Element --------------------*/
374 struct ses_ctrl_temp_sensor {
375 	struct ses_ctrl_common common;
376 	uint8_t bytes[3];
377 };
378 
379 enum ses_ctrl_temp_sensor_field_data {
380 	SES_CTRL_TEMP_SENSOR_RQST_IDENT_BYTE	= 0,
381 	SES_CTRL_TEMP_SENSOR_RQST_IDENT_MASK	= 0x80,
382 	SES_CTRL_TEMP_SENSOR_RQST_IDENT_SHIFT	= 7,
383 
384 	SES_CTRL_TEMP_SENSOR_RQST_FAIL_BYTE	= 0,
385 	SES_CTRL_TEMP_SENSOR_RQST_FAIL_MASK	= 0x40,
386 	SES_CTRL_TEMP_SENSOR_RQST_FAIL_SHIFT	= 6
387 };
388 
389 #define GEN_SES_CTRL_TEMP_SENSOR_ACCESSORS(LCASE, UCASE)	\
390     GEN_ACCESSORS(ses_ctrl_temp_sensor, SES_CTRL_TEMP_SENSOR, LCASE, UCASE)
391 GEN_SES_CTRL_TEMP_SENSOR_ACCESSORS(rqst_ident, RQST_IDENT)
392 GEN_SES_CTRL_TEMP_SENSOR_ACCESSORS(rqst_fail,  RQST_FAIL)
393 #undef GEN_SES_CTRL_TEMP_SENSOR_ACCESSORS
394 
395 /*------------------------- Door Lock Control Element ------------------------*/
396 struct ses_ctrl_door_lock {
397 	struct ses_ctrl_common common;
398 	uint8_t bytes[3];
399 };
400 
401 enum ses_ctrl_door_lock_field_data {
402 	SES_CTRL_DOOR_LOCK_RQST_IDENT_BYTE	= 0,
403 	SES_CTRL_DOOR_LOCK_RQST_IDENT_MASK	= 0x80,
404 	SES_CTRL_DOOR_LOCK_RQST_IDENT_SHIFT	= 7,
405 
406 	SES_CTRL_DOOR_LOCK_RQST_FAIL_BYTE	= 0,
407 	SES_CTRL_DOOR_LOCK_RQST_FAIL_MASK	= 0x40,
408 	SES_CTRL_DOOR_LOCK_RQST_FAIL_SHIFT	= 6,
409 
410 	SES_CTRL_DOOR_LOCK_UNLOCK_BYTE		= 2,
411 	SES_CTRL_DOOR_LOCK_UNLOCK_MASK		= 0x01,
412 	SES_CTRL_DOOR_LOCK_UNLOCK_SHIFT		= 0
413 };
414 
415 #define GEN_SES_CTRL_DOOR_LOCK_ACCESSORS(LCASE, UCASE)	\
416     GEN_ACCESSORS(ses_ctrl_door_lock, SES_CTRL_DOOR_LOCK, LCASE, UCASE)
417 GEN_SES_CTRL_DOOR_LOCK_ACCESSORS(rqst_ident, RQST_IDENT)
418 GEN_SES_CTRL_DOOR_LOCK_ACCESSORS(rqst_fail,  RQST_FAIL)
419 GEN_SES_CTRL_DOOR_LOCK_ACCESSORS(unlock,     UNLOCK)
420 #undef GEN_SES_CTRL_DOOR_LOCK_ACCESSORS
421 
422 /*----------------------- Audible Alarm Control Element ----------------------*/
423 struct ses_ctrl_audible_alarm {
424 	struct ses_ctrl_common common;
425 	uint8_t bytes[3];
426 };
427 
428 enum ses_ctrl_audible_alarm_field_data {
429 	SES_CTRL_AUDIBLE_ALARM_RQST_IDENT_BYTE		= 0,
430 	SES_CTRL_AUDIBLE_ALARM_RQST_IDENT_MASK		= 0x80,
431 	SES_CTRL_AUDIBLE_ALARM_RQST_IDENT_SHIFT		= 7,
432 
433 	SES_CTRL_AUDIBLE_ALARM_RQST_FAIL_BYTE		= 0,
434 	SES_CTRL_AUDIBLE_ALARM_RQST_FAIL_MASK		= 0x40,
435 	SES_CTRL_AUDIBLE_ALARM_RQST_FAIL_SHIFT		= 6,
436 
437 	SES_CTRL_AUDIBLE_ALARM_SET_MUTE_BYTE		= 2,
438 	SES_CTRL_AUDIBLE_ALARM_SET_MUTE_MASK		= 0x40,
439 	SES_CTRL_AUDIBLE_ALARM_SET_MUTE_SHIFT		= 6,
440 
441 	SES_CTRL_AUDIBLE_ALARM_SET_REMIND_BYTE		= 2,
442 	SES_CTRL_AUDIBLE_ALARM_SET_REMIND_MASK		= 0x10,
443 	SES_CTRL_AUDIBLE_ALARM_SET_REMIND_SHIFT		= 4,
444 
445 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_BYTE	= 2,
446 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_MASK	= 0x0F,
447 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_SHIFT	= 0,
448 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_INFO	= 0x08,
449 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_NON_CRIT	= 0x04,
450 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_CRIT	= 0x02,
451 	SES_CTRL_AUDIBLE_ALARM_TONE_CONTROL_UNRECOV	= 0x01
452 };
453 
454 #define GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(LCASE, UCASE)	\
455     GEN_ACCESSORS(ses_ctrl_audible_alarm, SES_CTRL_AUDIBLE_ALARM, LCASE, UCASE)
456 GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(rqst_ident,   RQST_IDENT)
457 GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(rqst_fail,    RQST_FAIL)
458 GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(set_mute,     SET_MUTE)
459 GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(set_remind,   SET_REMIND)
460 GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS(tone_control, TONE_CONTROL)
461 #undef GEN_SES_CTRL_AUDIBLE_ALARM_ACCESSORS
462 
463 /*--------- Enclosure Services Controller Electronics Control Element --------*/
464 struct ses_ctrl_ecc_electronics {
465 	struct ses_ctrl_common common;
466 	uint8_t bytes[3];
467 };
468 
469 enum ses_ctrl_ecc_electronics_field_data {
470 	SES_CTRL_ECC_ELECTRONICS_RQST_IDENT_BYTE	= 0,
471 	SES_CTRL_ECC_ELECTRONICS_RQST_IDENT_MASK	= 0x80,
472 	SES_CTRL_ECC_ELECTRONICS_RQST_IDENT_SHIFT	= 7,
473 
474 	SES_CTRL_ECC_ELECTRONICS_RQST_FAIL_BYTE		= 0,
475 	SES_CTRL_ECC_ELECTRONICS_RQST_FAIL_MASK		= 0x40,
476 	SES_CTRL_ECC_ELECTRONICS_RQST_FAIL_SHIFT	= 6,
477 
478 	SES_CTRL_ECC_ELECTRONICS_SELECT_ELEMENT_BYTE	= 1,
479 	SES_CTRL_ECC_ELECTRONICS_SELECT_ELEMENT_MASK	= 0x01,
480 	SES_CTRL_ECC_ELECTRONICS_SELECT_ELEMENT_SHIFT	= 0
481 };
482 
483 #define GEN_SES_CTRL_ECC_ELECTRONICS_ACCESSORS(LCASE, UCASE)		\
484     GEN_ACCESSORS(ses_ctrl_ecc_electronics, SES_CTRL_ECC_ELECTRONICS,	\
485 		  LCASE, UCASE)
486 GEN_SES_CTRL_ECC_ELECTRONICS_ACCESSORS(rqst_ident,     RQST_IDENT)
487 GEN_SES_CTRL_ECC_ELECTRONICS_ACCESSORS(rqst_fail,      RQST_FAIL)
488 GEN_SES_CTRL_ECC_ELECTRONICS_ACCESSORS(select_element, SELECT_ELEMENT)
489 #undef GEN_SES_CTRL_ECC_ELECTRONICS_ACCESSORS
490 
491 /*----------- SCSI Services Controller Electronics Control Element -----------*/
492 struct ses_ctrl_scc_electronics {
493 	struct ses_ctrl_common common;
494 	uint8_t bytes[3];
495 };
496 
497 enum ses_ctrl_scc_electronics_field_data {
498 	SES_CTRL_SCC_ELECTRONICS_RQST_IDENT_BYTE	= 0,
499 	SES_CTRL_SCC_ELECTRONICS_RQST_IDENT_MASK	= 0x80,
500 	SES_CTRL_SCC_ELECTRONICS_RQST_IDENT_SHIFT	= 7,
501 
502 	SES_CTRL_SCC_ELECTRONICS_RQST_FAIL_BYTE		= 0,
503 	SES_CTRL_SCC_ELECTRONICS_RQST_FAIL_MASK		= 0x40,
504 	SES_CTRL_SCC_ELECTRONICS_RQST_FAIL_SHIFT	= 6
505 };
506 
507 #define GEN_SES_CTRL_SCC_ELECTRONICS_ACCESSORS(LCASE, UCASE)		\
508     GEN_ACCESSORS(ses_ctrl_scc_electronics, SES_CTRL_SCC_ELECTRONICS,	\
509 		  LCASE, UCASE)
510 GEN_SES_CTRL_SCC_ELECTRONICS_ACCESSORS(rqst_ident, RQST_IDENT)
511 GEN_SES_CTRL_SCC_ELECTRONICS_ACCESSORS(rqst_fail,  RQST_FAIL)
512 #undef GEN_SES_CTRL_SCC_ELECTRONICS_ACCESSORS
513 
514 /*--------------------- Nonvolatile Cache Control Element --------------------*/
515 struct ses_ctrl_nv_cache {
516 	struct ses_ctrl_common common;
517 	uint8_t bytes[3];
518 };
519 
520 enum ses_ctrl_nv_cache_field_data {
521 	SES_CTRL_NV_CACHE_RQST_IDENT_BYTE	= 0,
522 	SES_CTRL_NV_CACHE_RQST_IDENT_MASK	= 0x80,
523 	SES_CTRL_NV_CACHE_RQST_IDENT_SHIFT	= 7,
524 
525 	SES_CTRL_NV_CACHE_RQST_FAIL_BYTE	= 0,
526 	SES_CTRL_NV_CACHE_RQST_FAIL_MASK	= 0x40,
527 	SES_CTRL_NV_CACHE_RQST_FAIL_SHIFT	= 6
528 };
529 
530 #define GEN_SES_CTRL_NV_CACHE_ACCESSORS(LCASE, UCASE)		\
531     GEN_ACCESSORS(ses_ctrl_nv_cache, SES_CTRL_NV_CACHE,	LCASE, UCASE)
532 GEN_SES_CTRL_NV_CACHE_ACCESSORS(rqst_ident, RQST_IDENT)
533 GEN_SES_CTRL_NV_CACHE_ACCESSORS(rqst_fail,  RQST_FAIL)
534 #undef GEN_SES_CTRL_NV_CACHE_ACCESSORS
535 
536 /*----------------- Invalid Operation Reason Control Element -----------------*/
537 struct ses_ctrl_invalid_op_reason {
538 	struct ses_ctrl_common common;
539 	uint8_t bytes[3];
540 };
541 
542 /* There are no element specific fields currently defined in the spec. */
543 
544 /*--------------- Uninterruptible Power Supply Control Element ---------------*/
545 struct ses_ctrl_ups {
546 	struct ses_ctrl_common common;
547 	uint8_t bytes[3];
548 };
549 
550 enum ses_ctrl_ups_field_data {
551 	SES_CTRL_UPS_RQST_IDENT_BYTE	= 2,
552 	SES_CTRL_UPS_RQST_IDENT_MASK	= 0x80,
553 	SES_CTRL_UPS_RQST_IDENT_SHIFT	= 7,
554 
555 	SES_CTRL_UPS_RQST_FAIL_BYTE	= 2,
556 	SES_CTRL_UPS_RQST_FAIL_MASK	= 0x40,
557 	SES_CTRL_UPS_RQST_FAIL_SHIFT	= 6
558 };
559 
560 #define GEN_SES_CTRL_UPS_ACCESSORS(LCASE, UCASE)	\
561     GEN_ACCESSORS(ses_ctrl_ups, SES_CTRL_UPS, LCASE, UCASE)
562 GEN_SES_CTRL_UPS_ACCESSORS(rqst_ident, RQST_IDENT)
563 GEN_SES_CTRL_UPS_ACCESSORS(rqst_fail,  RQST_FAIL)
564 #undef GEN_SES_CTRL_UPS_ACCESSORS
565 
566 /*-------------------------- Display Control Element -------------------------*/
567 struct ses_ctrl_display {
568 	struct ses_ctrl_common common;
569 	uint8_t bytes[1];
570 	uint8_t display_character[2];
571 };
572 
573 enum ses_ctrl_display_field_data {
574 	SES_CTRL_DISPLAY_RQST_IDENT_BYTE	= 0,
575 	SES_CTRL_DISPLAY_RQST_IDENT_MASK	= 0x80,
576 	SES_CTRL_DISPLAY_RQST_IDENT_SHIFT	= 7,
577 
578 	SES_CTRL_DISPLAY_RQST_FAIL_BYTE		= 0,
579 	SES_CTRL_DISPLAY_RQST_FAIL_MASK		= 0x40,
580 	SES_CTRL_DISPLAY_RQST_FAIL_SHIFT	= 6,
581 
582 	SES_CTRL_DISPLAY_DISPLAY_MODE_BYTE	= 0,
583 	SES_CTRL_DISPLAY_DISPLAY_MODE_MASK	= 0x03,
584 	SES_CTRL_DISPLAY_DISPLAY_MODE_SHIFT	= 6,
585 	SES_CTRL_DISPLAY_DISPLAY_MODE_UNCHANGED = 0x0,
586 	SES_CTRL_DISPLAY_DISPLAY_MODE_ESP	= 0x1,
587 	SES_CTRL_DISPLAY_DISPLAY_MODE_DC_FIELD	= 0x2
588 };
589 
590 #define GEN_SES_CTRL_DISPLAY_ACCESSORS(LCASE, UCASE)	\
591     GEN_ACCESSORS(ses_ctrl_display, SES_CTRL_DISPLAY, LCASE, UCASE)
592 GEN_SES_CTRL_DISPLAY_ACCESSORS(rqst_ident,   RQST_IDENT)
593 GEN_SES_CTRL_DISPLAY_ACCESSORS(rqst_fail,    RQST_FAIL)
594 GEN_SES_CTRL_DISPLAY_ACCESSORS(display_mode, DISPLAY_MODE)
595 #undef GEN_SES_CTRL_DISPLAY_ACCESSORS
596 
597 /*----------------------- Key Pad Entry Control Element ----------------------*/
598 struct ses_ctrl_key_pad_entry {
599 	struct ses_ctrl_common common;
600 	uint8_t bytes[3];
601 };
602 
603 enum ses_ctrl_key_pad_entry_field_data {
604 	SES_CTRL_KEY_PAD_ENTRY_RQST_IDENT_BYTE	= 0,
605 	SES_CTRL_KEY_PAD_ENTRY_RQST_IDENT_MASK	= 0x80,
606 	SES_CTRL_KEY_PAD_ENTRY_RQST_IDENT_SHIFT	= 7,
607 
608 	SES_CTRL_KEY_PAD_ENTRY_RQST_FAIL_BYTE	= 0,
609 	SES_CTRL_KEY_PAD_ENTRY_RQST_FAIL_MASK	= 0x40,
610 	SES_CTRL_KEY_PAD_ENTRY_RQST_FAIL_SHIFT	= 6
611 };
612 
613 #define GEN_SES_CTRL_KEY_PAD_ENTRY_ACCESSORS(LCASE, UCASE)	\
614     GEN_ACCESSORS(ses_ctrl_key_pad_entry, SES_CTRL_KEY_PAD_ENTRY, LCASE, UCASE)
615 GEN_SES_CTRL_KEY_PAD_ENTRY_ACCESSORS(rqst_ident,   RQST_IDENT)
616 GEN_SES_CTRL_KEY_PAD_ENTRY_ACCESSORS(rqst_fail,    RQST_FAIL)
617 #undef GEN_SES_CTRL_KEY_PAD_ENTRY_ACCESSORS
618 
619 /*------------------------- Enclosure Control Element ------------------------*/
620 struct ses_ctrl_enclosure {
621 	struct ses_ctrl_common common;
622 	uint8_t bytes[3];
623 };
624 
625 enum ses_ctrl_enclosure_field_data {
626 	SES_CTRL_ENCLOSURE_RQST_IDENT_BYTE		= 0,
627 	SES_CTRL_ENCLOSURE_RQST_IDENT_MASK		= 0x80,
628 	SES_CTRL_ENCLOSURE_RQST_IDENT_SHIFT		= 7,
629 
630 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_BYTE	= 1,
631 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_MASK	= 0xC0,
632 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_SHIFT	= 6,
633 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_NONE	= 0x0,
634 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_AFTER_DELAY	= 0x1,
635 	SES_CTRL_ENCLOSURE_POWER_CYCLE_RQST_CANCEL	= 0x2,
636 
637 	SES_CTRL_ENCLOSURE_POWER_CYCLE_DELAY_BYTE	= 1,
638 	SES_CTRL_ENCLOSURE_POWER_CYCLE_DELAY_MASK	= 0x3F,
639 	SES_CTRL_ENCLOSURE_POWER_CYCLE_DELAY_SHIFT	= 0,
640 	SES_CTRL_ENCLOSURE_POWER_CYCLE_DELAY_MAX	= 60,/*minutes*/
641 
642 	SES_CTRL_ENCLOSURE_POWER_OFF_DURATION_BYTE	= 2,
643 	SES_CTRL_ENCLOSURE_POWER_OFF_DURATION_MASK	= 0xFC,
644 	SES_CTRL_ENCLOSURE_POWER_OFF_DURATION_SHIFT	= 2,
645 	SES_CTRL_ENCLOSURE_POWER_OFF_DURATION_MAX_AUTO	= 60,
646 	SES_CTRL_ENCLOSURE_POWER_OFF_DURATION_MANUAL	= 63,
647 
648 	SES_CTRL_ENCLOSURE_RQST_FAIL_BYTE		= 2,
649 	SES_CTRL_ENCLOSURE_RQST_FAIL_MASK		= 0x02,
650 	SES_CTRL_ENCLOSURE_RQST_FAIL_SHIFT		= 1,
651 
652 	SES_CTRL_ENCLOSURE_RQST_WARN_BYTE		= 2,
653 	SES_CTRL_ENCLOSURE_RQST_WARN_MASK		= 0x01,
654 	SES_CTRL_ENCLOSURE_RQST_WARN_SHIFT		= 0
655 };
656 
657 #define GEN_SES_CTRL_ENCLOSURE_ACCESSORS(LCASE, UCASE)		\
658     GEN_ACCESSORS(ses_ctrl_enclosure, SES_CTRL_ENCLOSURE, LCASE, UCASE)
659 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(rqst_ident,         RQST_IDENT)
660 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(power_cycle_rqst,   POWER_CYCLE_RQST)
661 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(power_cycle_delay,  POWER_CYCLE_DELAY)
662 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(power_off_duration, POWER_OFF_DURATION)
663 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(rqst_fail,          RQST_FAIL)
664 GEN_SES_CTRL_ENCLOSURE_ACCESSORS(rqst_warn,          RQST_WARN)
665 #undef GEN_SES_CTRL_ENCLOSURE_ACCESSORS
666 
667 /*------------------- SCSI Port/Transceiver Control Element ------------------*/
668 struct ses_ctrl_scsi_port_or_xcvr {
669 	struct ses_ctrl_common common;
670 	uint8_t bytes[3];
671 };
672 
673 enum ses_ctrl_scsi_port_or_xcvr_field_data {
674 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_IDENT_BYTE	= 0,
675 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_IDENT_MASK	= 0x80,
676 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_IDENT_SHIFT	= 7,
677 
678 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_FAIL_BYTE	= 0,
679 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_FAIL_MASK	= 0x40,
680 	SES_CTRL_SCSI_PORT_OR_XCVR_RQST_FAIL_SHIFT	= 6,
681 
682 	SES_CTRL_SCSI_PORT_OR_XCVR_DISABLE_BYTE		= 2,
683 	SES_CTRL_SCSI_PORT_OR_XCVR_DISABLE_MASK		= 0x10,
684 	SES_CTRL_SCSI_PORT_OR_XCVR_DISABLE_SHIFT	= 4
685 };
686 
687 #define GEN_SES_CTRL_SCSI_PORT_OR_XCVR_ACCESSORS(LCASE, UCASE)		 \
688     GEN_ACCESSORS(ses_ctrl_scsi_port_or_xcvr, SES_CTRL_SCSI_PORT_OR_XCVR,\
689 		  LCASE, UCASE)
690 GEN_SES_CTRL_SCSI_PORT_OR_XCVR_ACCESSORS(rqst_ident, RQST_IDENT)
691 GEN_SES_CTRL_SCSI_PORT_OR_XCVR_ACCESSORS(disable,    DISABLE)
692 GEN_SES_CTRL_SCSI_PORT_OR_XCVR_ACCESSORS(rqst_fail,  RQST_FAIL)
693 #undef GEN_SES_CTRL_SCSI_PORT_OR_XCVR_ACCESSORS
694 
695 /*------------------------- Language Control Element -------------------------*/
696 struct ses_ctrl_language {
697 	struct ses_ctrl_common common;
698 	uint8_t bytes[1];
699 	uint8_t language_code[2];
700 };
701 
702 enum ses_ctrl_language_field_data {
703 	SES_CTRL_LANGUAGE_RQST_IDENT_BYTE	= 0,
704 	SES_CTRL_LANGUAGE_RQST_IDENT_MASK	= 0x80,
705 	SES_CTRL_LANGUAGE_RQST_IDENT_SHIFT	= 7
706 };
707 
708 #define GEN_SES_CTRL_LANGUAGE_ACCESSORS(LCASE, UCASE)		 \
709     GEN_ACCESSORS(ses_ctrl_language, SES_CTRL_LANGUAGE, LCASE, UCASE)
710 GEN_SES_CTRL_LANGUAGE_ACCESSORS(rqst_ident, RQST_IDENT)
711 #undef GEN_SES_CTRL_LANGUAGE_ACCESSORS
712 
713 /*-------------------- Communication Port Control Element --------------------*/
714 struct ses_ctrl_comm_port {
715 	struct ses_ctrl_common common;
716 	uint8_t bytes[3];
717 };
718 
719 enum ses_ctrl_comm_port_field_data {
720 	SES_CTRL_COMM_PORT_RQST_IDENT_BYTE	= 0,
721 	SES_CTRL_COMM_PORT_RQST_IDENT_MASK	= 0x80,
722 	SES_CTRL_COMM_PORT_RQST_IDENT_SHIFT	= 7,
723 
724 	SES_CTRL_COMM_PORT_RQST_FAIL_BYTE	= 0,
725 	SES_CTRL_COMM_PORT_RQST_FAIL_MASK	= 0x40,
726 	SES_CTRL_COMM_PORT_RQST_FAIL_SHIFT	= 6,
727 
728 	SES_CTRL_COMM_PORT_DISABLE_BYTE		= 2,
729 	SES_CTRL_COMM_PORT_DISABLE_MASK		= 0x01,
730 	SES_CTRL_COMM_PORT_DISABLE_SHIFT	= 0
731 };
732 
733 #define GEN_SES_CTRL_COMM_PORT_ACCESSORS(LCASE, UCASE)		 \
734     GEN_ACCESSORS(ses_ctrl_comm_port, SES_CTRL_COMM_PORT, LCASE, UCASE)
735 GEN_SES_CTRL_COMM_PORT_ACCESSORS(rqst_ident, RQST_IDENT)
736 GEN_SES_CTRL_COMM_PORT_ACCESSORS(rqst_fail,  RQST_FAIL)
737 GEN_SES_CTRL_COMM_PORT_ACCESSORS(disable,    DISABLE)
738 #undef GEN_SES_CTRL_COMM_PORT_ACCESSORS
739 
740 /*---------------------- Voltage Sensor Control Element ----------------------*/
741 struct ses_ctrl_voltage_sensor {
742 	struct ses_ctrl_common common;
743 	uint8_t bytes[3];
744 };
745 
746 enum ses_ctrl_voltage_sensor_field_data {
747 	SES_CTRL_VOLTAGE_SENSOR_RQST_IDENT_BYTE		= 0,
748 	SES_CTRL_VOLTAGE_SENSOR_RQST_IDENT_MASK		= 0x80,
749 	SES_CTRL_VOLTAGE_SENSOR_RQST_IDENT_SHIFT	= 7,
750 
751 	SES_CTRL_VOLTAGE_SENSOR_RQST_FAIL_BYTE		= 0,
752 	SES_CTRL_VOLTAGE_SENSOR_RQST_FAIL_MASK		= 0x40,
753 	SES_CTRL_VOLTAGE_SENSOR_RQST_FAIL_SHIFT		= 6
754 };
755 
756 #define GEN_SES_CTRL_VOLTAGE_SENSOR_ACCESSORS(LCASE, UCASE)		\
757     GEN_ACCESSORS(ses_ctrl_voltage_sensor, SES_CTRL_VOLTAGE_SENSOR,	\
758 		  LCASE, UCASE)
759 GEN_SES_CTRL_VOLTAGE_SENSOR_ACCESSORS(rqst_ident, RQST_IDENT)
760 GEN_SES_CTRL_VOLTAGE_SENSOR_ACCESSORS(rqst_fail,  RQST_FAIL)
761 #undef GEN_SES_CTRL_VOLTAGE_SENSOR_ACCESSORS
762 
763 /*---------------------- Current Sensor Control Element ----------------------*/
764 struct ses_ctrl_current_sensor {
765 	struct ses_ctrl_common common;
766 	uint8_t bytes[3];
767 };
768 
769 enum ses_ctrl_current_sensor_field_data {
770 	SES_CTRL_CURRENT_SENSOR_RQST_IDENT_BYTE		= 0,
771 	SES_CTRL_CURRENT_SENSOR_RQST_IDENT_MASK		= 0x80,
772 	SES_CTRL_CURRENT_SENSOR_RQST_IDENT_SHIFT	= 7,
773 
774 	SES_CTRL_CURRENT_SENSOR_RQST_FAIL_BYTE		= 0,
775 	SES_CTRL_CURRENT_SENSOR_RQST_FAIL_MASK		= 0x40,
776 	SES_CTRL_CURRENT_SENSOR_RQST_FAIL_SHIFT		= 6
777 };
778 
779 #define GEN_SES_CTRL_CURRENT_SENSOR_ACCESSORS(LCASE, UCASE)		\
780     GEN_ACCESSORS(ses_ctrl_current_sensor, SES_CTRL_CURRENT_SENSOR,	\
781 		  LCASE, UCASE)
782 GEN_SES_CTRL_CURRENT_SENSOR_ACCESSORS(rqst_ident, RQST_IDENT)
783 GEN_SES_CTRL_CURRENT_SENSOR_ACCESSORS(rqst_fail,  RQST_FAIL)
784 #undef GEN_SES_CTRL_CURRENT_SENSOR_ACCESSORS
785 
786 /*--------------------- SCSI Target Port Control Element ---------------------*/
787 struct ses_ctrl_target_port {
788 	struct ses_ctrl_common common;
789 	uint8_t bytes[3];
790 };
791 
792 enum ses_ctrl_scsi_target_port_field_data {
793 	SES_CTRL_TARGET_PORT_RQST_IDENT_BYTE	= 0,
794 	SES_CTRL_TARGET_PORT_RQST_IDENT_MASK	= 0x80,
795 	SES_CTRL_TARGET_PORT_RQST_IDENT_SHIFT	= 7,
796 
797 	SES_CTRL_TARGET_PORT_RQST_FAIL_BYTE	= 0,
798 	SES_CTRL_TARGET_PORT_RQST_FAIL_MASK	= 0x40,
799 	SES_CTRL_TARGET_PORT_RQST_FAIL_SHIFT	= 6,
800 
801 	SES_CTRL_TARGET_PORT_ENABLE_BYTE	= 2,
802 	SES_CTRL_TARGET_PORT_ENABLE_MASK	= 0x01,
803 	SES_CTRL_TARGET_PORT_ENABLE_SHIFT	= 0
804 };
805 
806 #define GEN_SES_CTRL_TARGET_PORT_ACCESSORS(LCASE, UCASE)	\
807     GEN_ACCESSORS(ses_ctrl_target_port, SES_CTRL_TARGET_PORT, LCASE, UCASE)
808 GEN_SES_CTRL_TARGET_PORT_ACCESSORS(rqst_ident, RQST_IDENT)
809 GEN_SES_CTRL_TARGET_PORT_ACCESSORS(rqst_fail,  RQST_FAIL)
810 GEN_SES_CTRL_TARGET_PORT_ACCESSORS(enable,     ENABLE)
811 #undef GEN_SES_CTRL_TARGET_PORT_ACCESSORS
812 
813 /*-------------------- SCSI Initiator Port Control Element -------------------*/
814 struct ses_ctrl_initiator_port {
815 	struct ses_ctrl_common common;
816 	uint8_t bytes[3];
817 };
818 
819 enum ses_ctrl_initiator_port_field_data {
820 	SES_CTRL_INITIATOR_PORT_RQST_IDENT_BYTE		= 0,
821 	SES_CTRL_INITIATOR_PORT_RQST_IDENT_MASK		= 0x80,
822 	SES_CTRL_INITIATOR_PORT_RQST_IDENT_SHIFT	= 7,
823 
824 	SES_CTRL_INITIATOR_PORT_RQST_FAIL_BYTE		= 0,
825 	SES_CTRL_INITIATOR_PORT_RQST_FAIL_MASK		= 0x40,
826 	SES_CTRL_INITIATOR_PORT_RQST_FAIL_SHIFT		= 6,
827 
828 	SES_CTRL_INITIATOR_PORT_ENABLE_BYTE		= 2,
829 	SES_CTRL_INITIATOR_PORT_ENABLE_MASK		= 0x01,
830 	SES_CTRL_INITIATOR_PORT_ENABLE_SHIFT		= 0
831 };
832 
833 #define GEN_SES_CTRL_INITIATOR_PORT_ACCESSORS(LCASE, UCASE)		\
834     GEN_ACCESSORS(ses_ctrl_initiator_port, SES_CTRL_INITIATOR_PORT,	\
835 		  LCASE, UCASE)
836 GEN_SES_CTRL_INITIATOR_PORT_ACCESSORS(rqst_ident, RQST_IDENT)
837 GEN_SES_CTRL_INITIATOR_PORT_ACCESSORS(rqst_fail,  RQST_FAIL)
838 GEN_SES_CTRL_INITIATOR_PORT_ACCESSORS(enable,     ENABLE)
839 #undef GEN_SES_CTRL_INITIATOR_PORT_ACCESSORS
840 
841 /*-------------------- Simple Subenclosure Control Element -------------------*/
842 struct ses_ctrl_simple_subenc {
843 	struct ses_ctrl_common common;
844 	uint8_t bytes[3];
845 };
846 
847 enum ses_ctrl_simple_subenc_field_data {
848 	SES_CTRL_SIMPlE_SUBSES_RQST_IDENT_BYTE	= 0,
849 	SES_CTRL_SIMPlE_SUBSES_RQST_IDENT_MASK	= 0x80,
850 	SES_CTRL_SIMPlE_SUBSES_RQST_IDENT_SHIFT	= 7,
851 
852 	SES_CTRL_SIMPlE_SUBSES_RQST_FAIL_BYTE	= 0,
853 	SES_CTRL_SIMPlE_SUBSES_RQST_FAIL_MASK	= 0x40,
854 	SES_CTRL_SIMPlE_SUBSES_RQST_FAIL_SHIFT	= 6
855 };
856 
857 #define GEN_SES_CTRL_SIMPlE_SUBSES_ACCESSORS(LCASE, UCASE)		\
858     GEN_ACCESSORS(ses_ctrl_simple_subenc, SES_CTRL_SIMPlE_SUBSES,	\
859 		  LCASE, UCASE)
860 GEN_SES_CTRL_SIMPlE_SUBSES_ACCESSORS(rqst_ident, RQST_IDENT)
861 GEN_SES_CTRL_SIMPlE_SUBSES_ACCESSORS(rqst_fail,  RQST_FAIL)
862 #undef GEN_SES_CTRL_SIMPlE_SUBSES_ACCESSORS
863 
864 /*----------------------- SAS Expander Control Element -----------------------*/
865 struct ses_ctrl_sas_expander {
866 	struct ses_ctrl_common common;
867 	uint8_t bytes[3];
868 };
869 
870 enum ses_ctrl_sas_expander_field_data {
871 	SES_CTRL_SAS_EXPANDER_RQST_IDENT_BYTE	= 0,
872 	SES_CTRL_SAS_EXPANDER_RQST_IDENT_MASK	= 0x80,
873 	SES_CTRL_SAS_EXPANDER_RQST_IDENT_SHIFT	= 7,
874 
875 	SES_CTRL_SAS_EXPANDER_RQST_FAIL_BYTE	= 0,
876 	SES_CTRL_SAS_EXPANDER_RQST_FAIL_MASK	= 0x40,
877 	SES_CTRL_SAS_EXPANDER_RQST_FAIL_SHIFT	= 6
878 };
879 
880 #define GEN_SES_CTRL_SAS_EXPANDER_ACCESSORS(LCASE, UCASE)	\
881     GEN_ACCESSORS(ses_ctrl_sas_expander, SES_CTRL_SAS_EXPANDER,	LCASE, UCASE)
882 GEN_SES_CTRL_SAS_EXPANDER_ACCESSORS(rqst_ident, RQST_IDENT)
883 GEN_SES_CTRL_SAS_EXPANDER_ACCESSORS(rqst_fail,  RQST_FAIL)
884 #undef GEN_SES_CTRL_SAS_EXPANDER_ACCESSORS
885 
886 /*----------------------- SAS Connector Control Element ----------------------*/
887 struct ses_ctrl_sas_connector {
888 	struct ses_ctrl_common common;
889 	uint8_t bytes[3];
890 };
891 
892 enum ses_ctrl_sas_connector_field_data {
893 	SES_CTRL_SAS_CONNECTOR_RQST_IDENT_BYTE		= 0,
894 	SES_CTRL_SAS_CONNECTOR_RQST_IDENT_MASK		= 0x80,
895 	SES_CTRL_SAS_CONNECTOR_RQST_IDENT_SHIFT		= 7,
896 
897 	SES_CTRL_SAS_CONNECTOR_RQST_FAIL_BYTE		= 2,
898 	SES_CTRL_SAS_CONNECTOR_RQST_FAIL_MASK		= 0x40,
899 	SES_CTRL_SAS_CONNECTOR_RQST_FAIL_SHIFT		= 6
900 };
901 
902 #define GEN_SES_CTRL_SAS_CONNECTOR_ACCESSORS(LCASE, UCASE)		\
903     GEN_ACCESSORS(ses_ctrl_sas_connector, SES_CTRL_SAS_CONNECTOR,	\
904 		  LCASE, UCASE)
905 GEN_SES_CTRL_SAS_CONNECTOR_ACCESSORS(rqst_ident, RQST_IDENT)
906 GEN_SES_CTRL_SAS_CONNECTOR_ACCESSORS(rqst_fail,  RQST_FAIL)
907 #undef GEN_SES_CTRL_SAS_CONNECTOR_ACCESSORS
908 
909 /*------------------------- Universal Control Element ------------------------*/
910 union ses_ctrl_element {
911 	struct ses_ctrl_common            common;
912 	struct ses_ctrl_dev_slot          dev_slot;
913 	struct ses_ctrl_array_dev_slot    array_dev_slot;
914 	struct ses_ctrl_power_supply      power_supply;
915 	struct ses_ctrl_cooling           cooling;
916 	struct ses_ctrl_temp_sensor       temp_sensor;
917 	struct ses_ctrl_door_lock         door_lock;
918 	struct ses_ctrl_audible_alarm     audible_alarm;
919 	struct ses_ctrl_ecc_electronics   ecc_electronics;
920 	struct ses_ctrl_scc_electronics   scc_electronics;
921 	struct ses_ctrl_nv_cache          nv_cache;
922 	struct ses_ctrl_invalid_op_reason invalid_op_reason;
923 	struct ses_ctrl_ups               ups;
924 	struct ses_ctrl_display           display;
925 	struct ses_ctrl_key_pad_entry     key_pad_entry;
926 	struct ses_ctrl_scsi_port_or_xcvr scsi_port_or_xcvr;
927 	struct ses_ctrl_language          language;
928 	struct ses_ctrl_comm_port         comm_port;
929 	struct ses_ctrl_voltage_sensor    voltage_sensor;
930 	struct ses_ctrl_current_sensor    current_sensor;
931 	struct ses_ctrl_target_port	  target_port;
932 	struct ses_ctrl_initiator_port    initiator_port;
933 	struct ses_ctrl_simple_subenc	  simple_subenc;
934 	struct ses_ctrl_sas_expander      sas_expander;
935 	struct ses_ctrl_sas_connector     sas_connector;
936 };
937 
938 /*--------------------- SCSI SES Control Diagnostic Page ---------------------*/
939 struct ses_ctrl_page {
940 	struct ses_page_hdr hdr;
941 	union ses_ctrl_element   elements[];
942 };
943 
944 enum ses_ctrl_page_field_data {
945 	SES_CTRL_PAGE_INFO_MASK		= 0x08,
946 	SES_CTRL_PAGE_INFO_SHIFT	= 3,
947 
948 	SES_CTRL_PAGE_NON_CRIT_MASK	= 0x04,
949 	SES_CTRL_PAGE_NON_CRIT_SHIFT	= 2,
950 
951 	SES_CTRL_PAGE_CRIT_MASK		= 0x02,
952 	SES_CTRL_PAGE_CRIT_SHIFT	= 1,
953 
954 	SES_CTRL_PAGE_UNRECOV_MASK	= 0x01,
955 	SES_CTRL_PAGE_UNRECOV_SHIFT	= 0
956 };
957 
958 #define GEN_SES_CTRL_PAGE_ACCESSORS(LCASE, UCASE) \
959     GEN_HDR_ACCESSORS(ses_ctrl_page, SES_CTRL_PAGE, LCASE, UCASE)
960 
961 GEN_SES_CTRL_PAGE_ACCESSORS(info,     INFO)
962 GEN_SES_CTRL_PAGE_ACCESSORS(non_crit, NON_CRIT)
963 GEN_SES_CTRL_PAGE_ACCESSORS(crit,     CRIT)
964 GEN_SES_CTRL_PAGE_ACCESSORS(unrecov,  UNRECOV)
965 #undef GEN_SES_CTRL_PAGE_ACCESSORS
966 
967 /*================= SCSI SES Status Diagnostic Page Structures ===============*/
968 struct ses_status_common {
969 	uint8_t bytes[1];
970 };
971 
972 enum ses_status_common_field_data {
973 	SES_STATUS_COMMON_PRDFAIL_BYTE			= 0,
974 	SES_STATUS_COMMON_PRDFAIL_MASK			= 0x40,
975 	SES_STATUS_COMMON_PRDFAIL_SHIFT			= 6,
976 
977 	SES_STATUS_COMMON_DISABLED_BYTE			= 0,
978 	SES_STATUS_COMMON_DISABLED_MASK			= 0x20,
979 	SES_STATUS_COMMON_DISABLED_SHIFT		= 5,
980 
981 	SES_STATUS_COMMON_SWAP_BYTE			= 0,
982 	SES_STATUS_COMMON_SWAP_MASK			= 0x10,
983 	SES_STATUS_COMMON_SWAP_SHIFT			= 4,
984 
985 	SES_STATUS_COMMON_ELEMENT_STATUS_CODE_BYTE	= 0,
986 	SES_STATUS_COMMON_ELEMENT_STATUS_CODE_MASK	= 0x0F,
987 	SES_STATUS_COMMON_ELEMENT_STATUS_CODE_SHIFT	= 0
988 };
989 
990 #define GEN_SES_STATUS_COMMON_ACCESSORS(LCASE, UCASE) \
991     GEN_GETTER(ses_status_common, SES_STATUS_COMMON, LCASE, UCASE)
992 
993 GEN_SES_STATUS_COMMON_ACCESSORS(prdfail,             PRDFAIL)
994 GEN_SES_STATUS_COMMON_ACCESSORS(disabled,            DISABLED)
995 GEN_SES_STATUS_COMMON_ACCESSORS(swap,                SWAP)
996 GEN_SES_STATUS_COMMON_ACCESSORS(element_status_code, ELEMENT_STATUS_CODE)
997 #undef GEN_SES_STATUS_COMMON_ACCESSORS
998 
999 /*------------------------- Device Slot Status Element -----------------------*/
1000 struct ses_status_dev_slot {
1001 	struct ses_status_common common;
1002 	uint8_t slot_address;
1003 	uint8_t bytes[2];
1004 };
1005 
1006 enum ses_status_dev_slot_field_data {
1007 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_A_BYTE	= 0,
1008 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_A_MASK	= 0x80,
1009 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_A_SHIFT	= 7,
1010 
1011 	SES_STATUS_DEV_SLOT_DO_NOT_REMOVE_BYTE		= 0,
1012 	SES_STATUS_DEV_SLOT_DO_NOT_REMOVE_MASK		= 0x40,
1013 	SES_STATUS_DEV_SLOT_DO_NOT_REMOVE_SHIFT		= 6,
1014 
1015 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_A_BYTE	= 0,
1016 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_A_MASK	= 0x20,
1017 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_A_SHIFT	= 5,
1018 
1019 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_B_BYTE	= 0,
1020 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_B_MASK	= 0x10,
1021 	SES_STATUS_DEV_SLOT_ENCLOSURE_BYPED_B_SHIFT	= 4,
1022 
1023 	SES_STATUS_DEV_SLOT_INSERT_READY_BYTE		= 0,
1024 	SES_STATUS_DEV_SLOT_INSERT_READY_MASK		= 0x08,
1025 	SES_STATUS_DEV_SLOT_INSERT_READY_SHIFT		= 3,
1026 
1027 	SES_STATUS_DEV_SLOT_REMOVE_BYTE			= 0,
1028 	SES_STATUS_DEV_SLOT_REMOVE_MASK			= 0x04,
1029 	SES_STATUS_DEV_SLOT_REMOVE_SHIFT		= 2,
1030 
1031 	SES_STATUS_DEV_SLOT_IDENT_BYTE			= 0,
1032 	SES_STATUS_DEV_SLOT_IDENT_MASK			= 0x02,
1033 	SES_STATUS_DEV_SLOT_IDENT_SHIFT			= 1,
1034 
1035 	SES_STATUS_DEV_SLOT_REPORT_BYTE			= 0,
1036 	SES_STATUS_DEV_SLOT_REPORT_MASK			= 0x01,
1037 	SES_STATUS_DEV_SLOT_REPORT_SHIFT		= 0,
1038 
1039 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_B_BYTE	= 1,
1040 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_B_MASK	= 0x80,
1041 	SES_STATUS_DEV_SLOT_APP_CLIENT_BYPED_B_SHIFT	= 7,
1042 
1043 	SES_STATUS_DEV_SLOT_FAULT_SENSED_BYTE		= 1,
1044 	SES_STATUS_DEV_SLOT_FAULT_SENSED_MASK		= 0x40,
1045 	SES_STATUS_DEV_SLOT_FAULT_SENSED_SHIFT		= 6,
1046 
1047 	SES_STATUS_DEV_SLOT_FAULT_REQUESTED_BYTE	= 1,
1048 	SES_STATUS_DEV_SLOT_FAULT_REQUESTED_MASK	= 0x20,
1049 	SES_STATUS_DEV_SLOT_FAULT_REQUESTED_SHIFT	= 5,
1050 
1051 	SES_STATUS_DEV_SLOT_DEVICE_OFF_BYTE		= 1,
1052 	SES_STATUS_DEV_SLOT_DEVICE_OFF_MASK		= 0x10,
1053 	SES_STATUS_DEV_SLOT_DEVICE_OFF_SHIFT		= 4,
1054 
1055 	SES_STATUS_DEV_SLOT_BYPED_A_BYTE		= 1,
1056 	SES_STATUS_DEV_SLOT_BYPED_A_MASK		= 0x08,
1057 	SES_STATUS_DEV_SLOT_BYPED_A_SHIFT		= 3,
1058 
1059 	SES_STATUS_DEV_SLOT_BYPED_B_BYTE		= 1,
1060 	SES_STATUS_DEV_SLOT_BYPED_B_MASK		= 0x04,
1061 	SES_STATUS_DEV_SLOT_BYPED_B_SHIFT		= 2,
1062 
1063 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_A_BYTE		= 1,
1064 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_A_MASK		= 0x02,
1065 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_A_SHIFT	= 1,
1066 
1067 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_B_BYTE		= 1,
1068 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_B_MASK		= 0x01,
1069 	SES_STATUS_DEV_SLOT_DEVICE_BYPED_B_SHIFT	= 0
1070 };
1071 #define GEN_SES_STATUS_DEV_SLOT_ACCESSORS(LCASE, UCASE) \
1072     GEN_GETTER(ses_status_dev_slot, SES_STATUS_DEV_SLOT, LCASE, UCASE)
1073 
1074 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(app_client_byped_a, APP_CLIENT_BYPED_A)
1075 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(do_not_remove,      DO_NOT_REMOVE)
1076 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(enclosure_byped_a,  ENCLOSURE_BYPED_A)
1077 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(enclosure_byped_b,  ENCLOSURE_BYPED_B)
1078 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(insert_ready,       INSERT_READY)
1079 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(remove,             REMOVE)
1080 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(ident,              IDENT)
1081 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(report,             REPORT)
1082 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(app_client_byped_b, APP_CLIENT_BYPED_B)
1083 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(fault_sensed,       FAULT_SENSED)
1084 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(fault_requested,    FAULT_REQUESTED)
1085 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(device_off,         DEVICE_OFF)
1086 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(byped_a,            BYPED_A)
1087 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(byped_b,            BYPED_B)
1088 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(device_byped_a,     DEVICE_BYPED_A)
1089 GEN_SES_STATUS_DEV_SLOT_ACCESSORS(device_byped_b,     DEVICE_BYPED_B)
1090 #undef GEN_SES_STATUS_DEV_SLOT_ACCESSORS
1091 
1092 /*---------------------- Array Device Slot Status Element --------------------*/
1093 struct ses_status_array_dev_slot {
1094 	struct ses_status_common common;
1095 	uint8_t bytes[3];
1096 };
1097 
1098 enum ses_status_array_dev_slot_field_data {
1099 	SES_STATUS_ARRAY_DEV_SLOT_OK_BYTE			= 0,
1100 	SES_STATUS_ARRAY_DEV_SLOT_OK_MASK			= 0x80,
1101 	SES_STATUS_ARRAY_DEV_SLOT_OK_SHIFT			= 7,
1102 
1103 	SES_STATUS_ARRAY_DEV_SLOT_RSVD_DEVICE_BYTE		= 0,
1104 	SES_STATUS_ARRAY_DEV_SLOT_RSVD_DEVICE_MASK		= 0x40,
1105 	SES_STATUS_ARRAY_DEV_SLOT_RSVD_DEVICE_SHIFT		= 6,
1106 
1107 	SES_STATUS_ARRAY_DEV_SLOT_HOT_SPARE_BYTE		= 0,
1108 	SES_STATUS_ARRAY_DEV_SLOT_HOT_SPARE_MASK		= 0x20,
1109 	SES_STATUS_ARRAY_DEV_SLOT_HOT_SPARE_SHIFT		= 5,
1110 
1111 	SES_STATUS_ARRAY_DEV_SLOT_CONS_CHECK_BYTE		= 0,
1112 	SES_STATUS_ARRAY_DEV_SLOT_CONS_CHECK_MASK		= 0x10,
1113 	SES_STATUS_ARRAY_DEV_SLOT_CONS_CHECK_SHIFT		= 4,
1114 
1115 	SES_STATUS_ARRAY_DEV_SLOT_IN_CRIT_ARRAY_BYTE		= 0,
1116 	SES_STATUS_ARRAY_DEV_SLOT_IN_CRIT_ARRAY_MASK		= 0x08,
1117 	SES_STATUS_ARRAY_DEV_SLOT_IN_CRIT_ARRAY_SHIFT		= 3,
1118 
1119 	SES_STATUS_ARRAY_DEV_SLOT_IN_FAILED_ARRAY_BYTE		= 0,
1120 	SES_STATUS_ARRAY_DEV_SLOT_IN_FAILED_ARRAY_MASK		= 0x04,
1121 	SES_STATUS_ARRAY_DEV_SLOT_IN_FAILED_ARRAY_SHIFT		= 2,
1122 
1123 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_BYTE		= 0,
1124 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_MASK		= 0x02,
1125 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_SHIFT		= 1,
1126 
1127 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_ABORT_BYTE	= 0,
1128 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_ABORT_MASK	= 0x01,
1129 	SES_STATUS_ARRAY_DEV_SLOT_REBUILD_REMAP_ABORT_SHIFT	= 0
1130 
1131 	/*
1132 	 * The remaining fields are identical to the device
1133 	 * slot element type.  Access them through the device slot
1134 	 * element type and its accessors.
1135 	 */
1136 };
1137 #define GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(LCASE, UCASE)		\
1138     GEN_GETTER(ses_status_array_dev_slot, SES_STATUS_ARRAY_DEV_SLOT,	\
1139 	       LCASE, UCASE)
1140 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(ok,              OK)
1141 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(rsvd_device,     RSVD_DEVICE)
1142 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(hot_spare,       HOT_SPARE)
1143 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(cons_check,      CONS_CHECK)
1144 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(in_crit_array,   IN_CRIT_ARRAY)
1145 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(in_failed_array, IN_FAILED_ARRAY)
1146 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(rebuild_remap,   REBUILD_REMAP)
1147 GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS(rebuild_remap_abort,
1148 					REBUILD_REMAP_ABORT)
1149 #undef GEN_SES_STATUS_ARRAY_DEV_SLOT_ACCESSORS
1150 
1151 /*----------------------- Power Supply Status Element ------------------------*/
1152 struct ses_status_power_supply {
1153 	struct ses_status_common common;
1154 	uint8_t bytes[3];
1155 };
1156 
1157 enum ses_status_power_supply_field_data {
1158 	SES_STATUS_POWER_SUPPLY_IDENT_BYTE		= 0,
1159 	SES_STATUS_POWER_SUPPLY_IDENT_MASK		= 0x80,
1160 	SES_STATUS_POWER_SUPPLY_IDENT_SHIFT		= 7,
1161 
1162 	SES_STATUS_POWER_SUPPLY_DC_OVER_VOLTAGE_BYTE	= 1,
1163 	SES_STATUS_POWER_SUPPLY_DC_OVER_VOLTAGE_MASK	= 0x08,
1164 	SES_STATUS_POWER_SUPPLY_DC_OVER_VOLTAGE_SHIFT	= 3,
1165 
1166 	SES_STATUS_POWER_SUPPLY_DC_UNDER_VOLTAGE_BYTE	= 1,
1167 	SES_STATUS_POWER_SUPPLY_DC_UNDER_VOLTAGE_MASK	= 0x04,
1168 	SES_STATUS_POWER_SUPPLY_DC_UNDER_VOLTAGE_SHIFT	= 2,
1169 
1170 	SES_STATUS_POWER_SUPPLY_DC_OVER_CURRENT_BYTE	= 1,
1171 	SES_STATUS_POWER_SUPPLY_DC_OVER_CURRENT_MASK	= 0x02,
1172 	SES_STATUS_POWER_SUPPLY_DC_OVER_CURRENT_SHIFT	= 1,
1173 
1174 	SES_STATUS_POWER_SUPPLY_HOT_SWAP_BYTE		= 2,
1175 	SES_STATUS_POWER_SUPPLY_HOT_SWAP_MASK		= 0x80,
1176 	SES_STATUS_POWER_SUPPLY_HOT_SWAP_SHIFT		= 7,
1177 
1178 	SES_STATUS_POWER_SUPPLY_FAIL_BYTE		= 2,
1179 	SES_STATUS_POWER_SUPPLY_FAIL_MASK		= 0x40,
1180 	SES_STATUS_POWER_SUPPLY_FAIL_SHIFT		= 6,
1181 
1182 	SES_STATUS_POWER_SUPPLY_REQUESTED_ON_BYTE	= 2,
1183 	SES_STATUS_POWER_SUPPLY_REQUESTED_ON_MASK	= 0x20,
1184 	SES_STATUS_POWER_SUPPLY_REQUESTED_ON_SHIFT	= 5,
1185 
1186 	SES_STATUS_POWER_SUPPLY_OFF_BYTE		= 2,
1187 	SES_STATUS_POWER_SUPPLY_OFF_MASK		= 0x10,
1188 	SES_STATUS_POWER_SUPPLY_OFF_SHIFT		= 4,
1189 
1190 	SES_STATUS_POWER_SUPPLY_OVERTMP_FAIL_BYTE	= 2,
1191 	SES_STATUS_POWER_SUPPLY_OVERTMP_FAIL_MASK	= 0x08,
1192 	SES_STATUS_POWER_SUPPLY_OVERTMP_FAIL_SHIFT	= 3,
1193 
1194 	SES_STATUS_POWER_SUPPLY_TEMP_WARN_BYTE		= 2,
1195 	SES_STATUS_POWER_SUPPLY_TEMP_WARN_MASK		= 0x04,
1196 	SES_STATUS_POWER_SUPPLY_TEMP_WARN_SHIFT		= 2,
1197 
1198 	SES_STATUS_POWER_SUPPLY_AC_FAIL_BYTE		= 2,
1199 	SES_STATUS_POWER_SUPPLY_AC_FAIL_MASK		= 0x02,
1200 	SES_STATUS_POWER_SUPPLY_AC_FAIL_SHIFT		= 1,
1201 
1202 	SES_STATUS_POWER_SUPPLY_DC_FAIL_BYTE		= 2,
1203 	SES_STATUS_POWER_SUPPLY_DC_FAIL_MASK		= 0x01,
1204 	SES_STATUS_POWER_SUPPLY_DC_FAIL_SHIFT		= 0
1205 };
1206 
1207 #define GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(LCASE, UCASE)	\
1208     GEN_GETTER(ses_status_power_supply, SES_STATUS_POWER_SUPPLY, LCASE, UCASE)
1209 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(ident,            IDENT)
1210 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(dc_over_voltage,  DC_OVER_VOLTAGE)
1211 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(dc_under_voltage, DC_UNDER_VOLTAGE)
1212 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(dc_over_current,  DC_OVER_CURRENT)
1213 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(hot_swap,         HOT_SWAP)
1214 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(fail,             FAIL)
1215 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(requested_on,     REQUESTED_ON)
1216 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(off,              OFF)
1217 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(overtmp_fail,     OVERTMP_FAIL)
1218 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(temp_warn,        TEMP_WARN)
1219 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(ac_fail,          AC_FAIL)
1220 GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS(dc_fail,          DC_FAIL)
1221 #undef GEN_SES_STATUS_POWER_SUPPLY_ACCESSORS
1222 
1223 /*-------------------------- Cooling Status Element --------------------------*/
1224 struct ses_status_cooling {
1225 	struct ses_status_common common;
1226 	uint8_t bytes[3];
1227 };
1228 
1229 enum ses_status_cooling_field_data {
1230 	SES_STATUS_COOLING_IDENT_BYTE			= 0,
1231 	SES_STATUS_COOLING_IDENT_MASK			= 0x80,
1232 	SES_STATUS_COOLING_IDENT_SHIFT			= 7,
1233 
1234 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_MSB_BYTE	= 0,
1235 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_MSB_MASK	= 0x07,
1236 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_MSB_SHIFT	= 0,
1237 
1238 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_LSB_BYTE	= 1,
1239 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_LSB_MASK	= 0xFF,
1240 	SES_STATUS_COOLING_ACTUAL_FAN_SPEED_LSB_SHIFT	= 0,
1241 
1242 	SES_STATUS_COOLING_HOT_SWAP_BYTE		= 2,
1243 	SES_STATUS_COOLING_HOT_SWAP_MASK		= 0x40,
1244 	SES_STATUS_COOLING_HOT_SWAP_SHIFT		= 6,
1245 
1246 	SES_STATUS_COOLING_FAIL_BYTE			= 2,
1247 	SES_STATUS_COOLING_FAIL_MASK			= 0x40,
1248 	SES_STATUS_COOLING_FAIL_SHIFT			= 6,
1249 
1250 	SES_STATUS_COOLING_REQUESTED_ON_BYTE		= 2,
1251 	SES_STATUS_COOLING_REQUESTED_ON_MASK		= 0x20,
1252 	SES_STATUS_COOLING_REQUESTED_ON_SHIFT		= 5,
1253 
1254 	SES_STATUS_COOLING_OFF_BYTE			= 2,
1255 	SES_STATUS_COOLING_OFF_MASK			= 0x20,
1256 	SES_STATUS_COOLING_OFF_SHIFT			= 5,
1257 
1258 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_BYTE	= 2,
1259 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_MASK	= 0x07,
1260 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_SHIFT	= 2,
1261 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_STOPPED	= 0x00,
1262 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_LOWEST	= 0x01,
1263 	SES_STATUS_COOLING_ACTUAL_SPEED_CODE_HIGHEST	= 0x07
1264 };
1265 
1266 #define GEN_SES_STATUS_COOLING_ACCESSORS(LCASE, UCASE)	\
1267     GEN_GETTER(ses_status_cooling, SES_STATUS_COOLING, LCASE, UCASE)
1268 GEN_SES_STATUS_COOLING_ACCESSORS(ident,                IDENT)
1269 GEN_SES_STATUS_COOLING_ACCESSORS(actual_fan_speed_msb, ACTUAL_FAN_SPEED_MSB)
1270 GEN_SES_STATUS_COOLING_ACCESSORS(actual_fan_speed_lsb, ACTUAL_FAN_SPEED_LSB)
1271 GEN_SES_STATUS_COOLING_ACCESSORS(hot_swap,             HOT_SWAP)
1272 GEN_SES_STATUS_COOLING_ACCESSORS(fail,                 FAIL)
1273 GEN_SES_STATUS_COOLING_ACCESSORS(requested_on,         REQUESTED_ON)
1274 GEN_SES_STATUS_COOLING_ACCESSORS(off,                  OFF)
1275 GEN_SES_STATUS_COOLING_ACCESSORS(actual_speed_code,    ACTUAL_SPEED_CODE)
1276 #undef GEN_SES_STATUS_COOLING_ACCESSORS
1277 
1278 static inline int
1279 ses_status_cooling_get_actual_fan_speed(struct ses_status_cooling *elem)
1280 {
1281 	return (ses_status_cooling_get_actual_fan_speed_msb(elem) << 8
1282 	      | ses_status_cooling_get_actual_fan_speed_lsb(elem));
1283 }
1284 
1285 /*-------------------- Temperature Sensor Status Element ---------------------*/
1286 struct ses_status_temp_sensor {
1287 	struct ses_status_common common;
1288 	uint8_t bytes[3];
1289 };
1290 
1291 enum ses_status_temp_sensor_field_data {
1292 	SES_STATUS_TEMP_SENSOR_IDENT_BYTE		= 0,
1293 	SES_STATUS_TEMP_SENSOR_IDENT_MASK		= 0x80,
1294 	SES_STATUS_TEMP_SENSOR_IDENT_SHIFT		= 7,
1295 
1296 	SES_STATUS_TEMP_SENSOR_FAIL_BYTE		= 0,
1297 	SES_STATUS_TEMP_SENSOR_FAIL_MASK		= 0x40,
1298 	SES_STATUS_TEMP_SENSOR_FAIL_SHIFT		= 6,
1299 
1300 	SES_STATUS_TEMP_SENSOR_TEMPERATURE_BYTE		= 1,
1301 	SES_STATUS_TEMP_SENSOR_TEMPERATURE_MASK		= 0xFF,
1302 	SES_STATUS_TEMP_SENSOR_TEMPERATURE_SHIFT	= 0,
1303 
1304 	SES_STATUS_TEMP_SENSOR_OT_FAILURE_BYTE		= 2,
1305 	SES_STATUS_TEMP_SENSOR_OT_FAILURE_MASK		= 0x08,
1306 	SES_STATUS_TEMP_SENSOR_OT_FAILURE_SHIFT		= 3,
1307 
1308 	SES_STATUS_TEMP_SENSOR_OT_WARNING_BYTE		= 2,
1309 	SES_STATUS_TEMP_SENSOR_OT_WARNING_MASK		= 0x04,
1310 	SES_STATUS_TEMP_SENSOR_OT_WARNING_SHIFT		= 2,
1311 
1312 	SES_STATUS_TEMP_SENSOR_UT_FAILURE_BYTE		= 2,
1313 	SES_STATUS_TEMP_SENSOR_UT_FAILURE_MASK		= 0x02,
1314 	SES_STATUS_TEMP_SENSOR_UT_FAILURE_SHIFT		= 1,
1315 
1316 	SES_STATUS_TEMP_SENSOR_UT_WARNING_BYTE		= 2,
1317 	SES_STATUS_TEMP_SENSOR_UT_WARNING_MASK		= 0x01,
1318 	SES_STATUS_TEMP_SENSOR_UT_WARNING_SHIFT		= 0
1319 };
1320 
1321 #define GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(LCASE, UCASE)	\
1322     GEN_GETTER(ses_status_temp_sensor, SES_STATUS_TEMP_SENSOR, LCASE, UCASE)
1323 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(ident,       IDENT)
1324 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(fail,        FAIL)
1325 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(temperature, TEMPERATURE)
1326 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(ot_failure,  OT_FAILURE)
1327 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(ot_warning,  OT_WARNING)
1328 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(ut_failure,  UT_FAILURE)
1329 GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS(ut_warning,  UT_WARNING)
1330 #undef GEN_SES_STATUS_TEMP_SENSOR_ACCESSORS
1331 
1332 /*------------------------- Door Lock Status Element -------------------------*/
1333 struct ses_status_door_lock {
1334 	struct ses_status_common common;
1335 	uint8_t bytes[3];
1336 };
1337 
1338 enum ses_status_door_lock_field_data {
1339 	SES_STATUS_DOOR_LOCK_IDENT_BYTE		= 0,
1340 	SES_STATUS_DOOR_LOCK_IDENT_MASK		= 0x80,
1341 	SES_STATUS_DOOR_LOCK_IDENT_SHIFT	= 7,
1342 
1343 	SES_STATUS_DOOR_LOCK_FAIL_BYTE		= 0,
1344 	SES_STATUS_DOOR_LOCK_FAIL_MASK		= 0x40,
1345 	SES_STATUS_DOOR_LOCK_FAIL_SHIFT		= 6,
1346 
1347 	SES_STATUS_DOOR_LOCK_UNLOCKED_BYTE	= 2,
1348 	SES_STATUS_DOOR_LOCK_UNLOCKED_MASK	= 0x01,
1349 	SES_STATUS_DOOR_LOCK_UNLOCKED_SHIFT	= 0
1350 };
1351 
1352 #define GEN_SES_STATUS_DOOR_LOCK_ACCESSORS(LCASE, UCASE)	\
1353     GEN_GETTER(ses_status_door_lock, SES_STATUS_DOOR_LOCK, LCASE, UCASE)
1354 GEN_SES_STATUS_DOOR_LOCK_ACCESSORS(ident,    IDENT)
1355 GEN_SES_STATUS_DOOR_LOCK_ACCESSORS(fail,     FAIL)
1356 GEN_SES_STATUS_DOOR_LOCK_ACCESSORS(unlocked, UNLOCKED)
1357 #undef GEN_SES_STATUS_DOOR_LOCK_ACCESSORS
1358 
1359 /*----------------------- Audible Alarm Status Element -----------------------*/
1360 struct ses_status_audible_alarm {
1361 	struct ses_status_common common;
1362 	uint8_t bytes[3];
1363 };
1364 
1365 enum ses_status_audible_alarm_field_data {
1366 	SES_STATUS_AUDIBLE_ALARM_IDENT_BYTE			= 0,
1367 	SES_STATUS_AUDIBLE_ALARM_IDENT_MASK			= 0x80,
1368 	SES_STATUS_AUDIBLE_ALARM_IDENT_SHIFT			= 7,
1369 
1370 	SES_STATUS_AUDIBLE_ALARM_FAIL_BYTE			= 0,
1371 	SES_STATUS_AUDIBLE_ALARM_FAIL_MASK			= 0x40,
1372 	SES_STATUS_AUDIBLE_ALARM_FAIL_SHIFT			= 6,
1373 
1374 	SES_STATUS_AUDIBLE_ALARM_RQST_MUTE_BYTE			= 2,
1375 	SES_STATUS_AUDIBLE_ALARM_RQST_MUTE_MASK			= 0x80,
1376 	SES_STATUS_AUDIBLE_ALARM_RQST_MUTE_SHIFT		= 7,
1377 
1378 	SES_STATUS_AUDIBLE_ALARM_MUTED_BYTE			= 2,
1379 	SES_STATUS_AUDIBLE_ALARM_MUTED_MASK			= 0x40,
1380 	SES_STATUS_AUDIBLE_ALARM_MUTED_SHIFT			= 6,
1381 
1382 	SES_STATUS_AUDIBLE_ALARM_REMIND_BYTE			= 2,
1383 	SES_STATUS_AUDIBLE_ALARM_REMIND_MASK			= 0x10,
1384 	SES_STATUS_AUDIBLE_ALARM_REMIND_SHIFT			= 4,
1385 
1386 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_BYTE		= 2,
1387 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_MASK		= 0x0F,
1388 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_SHIFT		= 0,
1389 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_INFO		= 0x08,
1390 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_NON_CRIT	= 0x04,
1391 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_CRIT		= 0x02,
1392 	SES_STATUS_AUDIBLE_ALARM_TONE_INDICATOR_UNRECOV		= 0x01
1393 };
1394 
1395 #define GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(LCASE, UCASE)	\
1396     GEN_GETTER(ses_status_audible_alarm, SES_STATUS_AUDIBLE_ALARM, LCASE, UCASE)
1397 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(ident,          IDENT)
1398 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(fail,           FAIL)
1399 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(rqst_mute,      RQST_MUTE)
1400 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(muted,          MUTED)
1401 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(remind,         REMIND)
1402 GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS(tone_indicator, TONE_INDICATOR)
1403 #undef GEN_SES_STATUS_AUDIBLE_ALARM_ACCESSORS
1404 
1405 /*---------- Enclosure Services Statusler Electronics Status Element ---------*/
1406 struct ses_status_ecc_electronics {
1407 	struct ses_status_common common;
1408 	uint8_t bytes[3];
1409 };
1410 
1411 enum ses_status_ecc_electronics_field_data {
1412 	SES_STATUS_ECC_ELECTRONICS_IDENT_BYTE		= 0,
1413 	SES_STATUS_ECC_ELECTRONICS_IDENT_MASK		= 0x80,
1414 	SES_STATUS_ECC_ELECTRONICS_IDENT_SHIFT		= 7,
1415 
1416 	SES_STATUS_ECC_ELECTRONICS_FAIL_BYTE		= 0,
1417 	SES_STATUS_ECC_ELECTRONICS_FAIL_MASK		= 0x40,
1418 	SES_STATUS_ECC_ELECTRONICS_FAIL_SHIFT		= 6,
1419 
1420 	SES_STATUS_ECC_ELECTRONICS_REPORT_BYTE		= 1,
1421 	SES_STATUS_ECC_ELECTRONICS_REPORT_MASK		= 0x01,
1422 	SES_STATUS_ECC_ELECTRONICS_REPORT_SHIFT		= 0,
1423 
1424 	SES_STATUS_ECC_ELECTRONICS_HOT_SWAP_BYTE	= 2,
1425 	SES_STATUS_ECC_ELECTRONICS_HOT_SWAP_MASK	= 0x80,
1426 	SES_STATUS_ECC_ELECTRONICS_HOT_SWAP_SHIFT	= 7
1427 };
1428 
1429 #define GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS(LCASE, UCASE)		\
1430     GEN_GETTER(ses_status_ecc_electronics, SES_STATUS_ECC_ELECTRONICS,	\
1431 		  LCASE, UCASE)
1432 GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS(ident,     IDENT)
1433 GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS(fail,      FAIL)
1434 GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS(report,    REPORT)
1435 GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS(hot_swap,  HOT_SWAP)
1436 #undef GEN_SES_STATUS_ECC_ELECTRONICS_ACCESSORS
1437 
1438 /*------------ SCSI Services Statusler Electronics Status Element ------------*/
1439 struct ses_status_scc_electronics {
1440 	struct ses_status_common common;
1441 	uint8_t bytes[3];
1442 };
1443 
1444 enum ses_status_scc_electronics_field_data {
1445 	SES_STATUS_SCC_ELECTRONICS_IDENT_BYTE	= 0,
1446 	SES_STATUS_SCC_ELECTRONICS_IDENT_MASK	= 0x80,
1447 	SES_STATUS_SCC_ELECTRONICS_IDENT_SHIFT	= 7,
1448 
1449 	SES_STATUS_SCC_ELECTRONICS_FAIL_BYTE	= 0,
1450 	SES_STATUS_SCC_ELECTRONICS_FAIL_MASK	= 0x40,
1451 	SES_STATUS_SCC_ELECTRONICS_FAIL_SHIFT	= 6,
1452 
1453 	SES_STATUS_SCC_ELECTRONICS_REPORT_BYTE	= 1,
1454 	SES_STATUS_SCC_ELECTRONICS_REPORT_MASK	= 0x01,
1455 	SES_STATUS_SCC_ELECTRONICS_REPORT_SHIFT	= 0
1456 };
1457 
1458 #define GEN_SES_STATUS_SCC_ELECTRONICS_ACCESSORS(LCASE, UCASE)		\
1459     GEN_GETTER(ses_status_scc_electronics, SES_STATUS_SCC_ELECTRONICS,	\
1460 		  LCASE, UCASE)
1461 GEN_SES_STATUS_SCC_ELECTRONICS_ACCESSORS(ident,     IDENT)
1462 GEN_SES_STATUS_SCC_ELECTRONICS_ACCESSORS(fail,      FAIL)
1463 GEN_SES_STATUS_SCC_ELECTRONICS_ACCESSORS(report,    REPORT)
1464 #undef GEN_SES_STATUS_SCC_ELECTRONICS_ACCESSORS
1465 
1466 /*--------------------- Nonvolatile Cache Status Element ---------------------*/
1467 struct ses_status_nv_cache {
1468 	struct ses_status_common common;
1469 	uint8_t bytes[1];
1470 	uint8_t cache_size[2];
1471 };
1472 
1473 enum ses_status_nv_cache_field_data {
1474 	SES_STATUS_NV_CACHE_IDENT_BYTE			= 0,
1475 	SES_STATUS_NV_CACHE_IDENT_MASK			= 0x80,
1476 	SES_STATUS_NV_CACHE_IDENT_SHIFT			= 7,
1477 
1478 	SES_STATUS_NV_CACHE_FAIL_BYTE			= 0,
1479 	SES_STATUS_NV_CACHE_FAIL_MASK			= 0x40,
1480 	SES_STATUS_NV_CACHE_FAIL_SHIFT			= 6,
1481 
1482 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_BYTE	= 0,
1483 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_MASK	= 0x03,
1484 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_SHIFT	= 0,
1485 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_BYTES	= 0x0,
1486 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_KBYTES	= 0x1,
1487 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_MBYTES	= 0x2,
1488 	SES_STATUS_NV_CACHE_SIZE_MULTIPLIER_GBYTES	= 0x3
1489 };
1490 
1491 #define GEN_SES_STATUS_NV_CACHE_ACCESSORS(LCASE, UCASE)		\
1492     GEN_GETTER(ses_status_nv_cache, SES_STATUS_NV_CACHE, LCASE, UCASE)
1493 GEN_SES_STATUS_NV_CACHE_ACCESSORS(ident,           IDENT)
1494 GEN_SES_STATUS_NV_CACHE_ACCESSORS(fail,            FAIL)
1495 GEN_SES_STATUS_NV_CACHE_ACCESSORS(size_multiplier, SIZE_MULTIPLIER)
1496 #undef GEN_SES_STATUS_NV_CACHE_ACCESSORS
1497 
1498 static inline uintmax_t
1499 ses_status_nv_cache_get_cache_size(struct ses_status_nv_cache *elem)
1500 {
1501 	uintmax_t cache_size;
1502 	int multiplier;
1503 
1504 	/* Multiplier is in units of 2^10 */
1505 	cache_size = scsi_2btoul(elem->cache_size);
1506 	multiplier = 10 * ses_status_nv_cache_get_size_multiplier(elem);
1507 	return (cache_size << multiplier);
1508 }
1509 
1510 /*----------------- Invalid Operation Reason Status Element ------------------*/
1511 struct ses_status_invalid_op_reason {
1512 	struct ses_status_common common;
1513 	uint8_t bytes[3];
1514 };
1515 
1516 enum ses_status_invalid_op_field_data {
1517 	SES_STATUS_INVALID_OP_REASON_TYPE_BYTE				= 0,
1518 	SES_STATUS_INVALID_OP_REASON_TYPE_MASK				= 0xC0,
1519 	SES_STATUS_INVALID_OP_REASON_TYPE_SHIFT				= 6,
1520 	SES_STATUS_INVALID_OP_REASON_TYPE_PC_ERROR			= 0x00,
1521 	SES_STATUS_INVALID_OP_REASON_TYPE_PF_ERROR			= 0x01,
1522 	SES_STATUS_INVALID_OP_REASON_TYPE_VS_ERROR			= 0x03,
1523 
1524 	SES_STATUS_INVALID_OP_REASON_PC_ERROR_PC_NOT_SUPPORTED_BYTE	= 0,
1525 	SES_STATUS_INVALID_OP_REASON_PC_ERROR_PC_NOT_SUPPORTED_MASK	= 0x01,
1526 	SES_STATUS_INVALID_OP_REASON_PC_ERROR_PC_NOT_SUPPORTED_SHIFT	= 0,
1527 
1528 	SES_STATUS_INVALID_OP_REASON_PF_ERROR_BIT_NUMBER_BYTE		= 0,
1529 	SES_STATUS_INVALID_OP_REASON_PF_ERROR_BIT_NUMBER_MASK		= 0x03,
1530 	SES_STATUS_INVALID_OP_REASON_PF_ERROR_BIT_NUMBER_SHIFT		= 0
1531 };
1532 
1533 #define GEN_SES_STATUS_INVALID_OP_REASON_ACCESSORS(LCASE, UCASE)	   \
1534     GEN_GETTER(ses_status_invalid_op_reason, SES_STATUS_INVALID_OP_REASON, \
1535 	       LCASE, UCASE)
1536 GEN_SES_STATUS_INVALID_OP_REASON_ACCESSORS(type, TYPE)
1537 GEN_SES_STATUS_INVALID_OP_REASON_ACCESSORS(pc_error_pc_not_supported,
1538 					   PC_ERROR_PC_NOT_SUPPORTED)
1539 GEN_SES_STATUS_INVALID_OP_REASON_ACCESSORS(pf_error_bit_number,
1540 					   PF_ERROR_BIT_NUMBER)
1541 #undef GEN_SES_STATUS_INVALID_OP_ACCESSORS
1542 
1543 /*--------------- Uninterruptible Power Supply Status Element ----------------*/
1544 struct ses_status_ups {
1545 	struct ses_status_common common;
1546 	/* Minutes of remaining capacity. */
1547 	uint8_t battery_status;
1548 	uint8_t bytes[2];
1549 };
1550 
1551 enum ses_status_ups_field_data {
1552 	SES_STATUS_UPS_AC_LO_BYTE	= 0,
1553 	SES_STATUS_UPS_AC_LO_MASK	= 0x80,
1554 	SES_STATUS_UPS_AC_LO_SHIFT	= 7,
1555 
1556 	SES_STATUS_UPS_AC_HI_BYTE	= 0,
1557 	SES_STATUS_UPS_AC_HI_MASK	= 0x40,
1558 	SES_STATUS_UPS_AC_HI_SHIFT	= 6,
1559 
1560 	SES_STATUS_UPS_AC_QUAL_BYTE	= 0,
1561 	SES_STATUS_UPS_AC_QUAL_MASK	= 0x20,
1562 	SES_STATUS_UPS_AC_QUAL_SHIFT	= 5,
1563 
1564 	SES_STATUS_UPS_AC_FAIL_BYTE	= 0,
1565 	SES_STATUS_UPS_AC_FAIL_MASK	= 0x10,
1566 	SES_STATUS_UPS_AC_FAIL_SHIFT	= 4,
1567 
1568 	SES_STATUS_UPS_DC_FAIL_BYTE	= 0,
1569 	SES_STATUS_UPS_DC_FAIL_MASK	= 0x08,
1570 	SES_STATUS_UPS_DC_FAIL_SHIFT	= 3,
1571 
1572 	SES_STATUS_UPS_UPS_FAIL_BYTE	= 0,
1573 	SES_STATUS_UPS_UPS_FAIL_MASK	= 0x04,
1574 	SES_STATUS_UPS_UPS_FAIL_SHIFT	= 2,
1575 
1576 	SES_STATUS_UPS_WARN_BYTE	= 0,
1577 	SES_STATUS_UPS_WARN_MASK	= 0x02,
1578 	SES_STATUS_UPS_WARN_SHIFT	= 1,
1579 
1580 	SES_STATUS_UPS_INTF_FAIL_BYTE	= 0,
1581 	SES_STATUS_UPS_INTF_FAIL_MASK	= 0x01,
1582 	SES_STATUS_UPS_INTF_FAIL_SHIFT	= 0,
1583 
1584 	SES_STATUS_UPS_IDENT_BYTE	= 0,
1585 	SES_STATUS_UPS_IDENT_MASK	= 0x80,
1586 	SES_STATUS_UPS_IDENT_SHIFT	= 7,
1587 
1588 	SES_STATUS_UPS_FAIL_BYTE	= 1,
1589 	SES_STATUS_UPS_FAIL_MASK	= 0x40,
1590 	SES_STATUS_UPS_FAIL_SHIFT	= 6,
1591 
1592 	SES_STATUS_UPS_BATT_FAIL_BYTE	= 1,
1593 	SES_STATUS_UPS_BATT_FAIL_MASK	= 0x02,
1594 	SES_STATUS_UPS_BATT_FAIL_SHIFT	= 1,
1595 
1596 	SES_STATUS_UPS_BPF_BYTE		= 1,
1597 	SES_STATUS_UPS_BPF_MASK		= 0x01,
1598 	SES_STATUS_UPS_BPF_SHIFT	= 0
1599 };
1600 
1601 #define GEN_SES_STATUS_UPS_ACCESSORS(LCASE, UCASE)	\
1602     GEN_GETTER(ses_status_ups, SES_STATUS_UPS, LCASE, UCASE)
1603 GEN_SES_STATUS_UPS_ACCESSORS(ac_lo,           AC_LO)
1604 GEN_SES_STATUS_UPS_ACCESSORS(ac_hi,            AC_HI)
1605 GEN_SES_STATUS_UPS_ACCESSORS(ac_qual,          AC_QUAL)
1606 GEN_SES_STATUS_UPS_ACCESSORS(ac_fail,          AC_FAIL)
1607 GEN_SES_STATUS_UPS_ACCESSORS(dc_fail,          DC_FAIL)
1608 GEN_SES_STATUS_UPS_ACCESSORS(ups_fail,         UPS_FAIL)
1609 GEN_SES_STATUS_UPS_ACCESSORS(warn,             WARN)
1610 GEN_SES_STATUS_UPS_ACCESSORS(intf_fail,        INTF_FAIL)
1611 GEN_SES_STATUS_UPS_ACCESSORS(ident,            IDENT)
1612 GEN_SES_STATUS_UPS_ACCESSORS(fail,             FAIL)
1613 GEN_SES_STATUS_UPS_ACCESSORS(batt_fail,        BATT_FAIL)
1614 GEN_SES_STATUS_UPS_ACCESSORS(bpf,              BPF)
1615 #undef GEN_SES_STATUS_UPS_ACCESSORS
1616 
1617 /*-------------------------- Display Status Element --------------------------*/
1618 struct ses_status_display {
1619 	struct ses_status_common common;
1620 	uint8_t bytes[1];
1621 	uint8_t display_character[2];
1622 };
1623 
1624 enum ses_status_display_field_data {
1625 	SES_STATUS_DISPLAY_IDENT_BYTE			= 0,
1626 	SES_STATUS_DISPLAY_IDENT_MASK			= 0x80,
1627 	SES_STATUS_DISPLAY_IDENT_SHIFT			= 7,
1628 
1629 	SES_STATUS_DISPLAY_FAIL_BYTE			= 0,
1630 	SES_STATUS_DISPLAY_FAIL_MASK			= 0x40,
1631 	SES_STATUS_DISPLAY_FAIL_SHIFT			= 6,
1632 
1633 	SES_STATUS_DISPLAY_DISPLAY_MODE_BYTE		= 0,
1634 	SES_STATUS_DISPLAY_DISPLAY_MODE_MASK		= 0x03,
1635 	SES_STATUS_DISPLAY_DISPLAY_MODE_SHIFT		= 6,
1636 	SES_STATUS_DISPLAY_DISPLAY_MODE_DC_FIELD_UNSUPP	= 0x0,
1637 	SES_STATUS_DISPLAY_DISPLAY_MODE_DC_FIELD_SUPP	= 0x1,
1638 	SES_STATUS_DISPLAY_DISPLAY_MODE_DC_FIELD	= 0x2
1639 };
1640 
1641 #define GEN_SES_STATUS_DISPLAY_ACCESSORS(LCASE, UCASE)	\
1642     GEN_GETTER(ses_status_display, SES_STATUS_DISPLAY, LCASE, UCASE)
1643 GEN_SES_STATUS_DISPLAY_ACCESSORS(ident,        IDENT)
1644 GEN_SES_STATUS_DISPLAY_ACCESSORS(fail,         FAIL)
1645 GEN_SES_STATUS_DISPLAY_ACCESSORS(display_mode, DISPLAY_MODE)
1646 #undef GEN_SES_STATUS_DISPLAY_ACCESSORS
1647 
1648 /*----------------------- Key Pad Entry Status Element -----------------------*/
1649 struct ses_status_key_pad_entry {
1650 	struct ses_status_common common;
1651 	uint8_t bytes[3];
1652 };
1653 
1654 enum ses_status_key_pad_entry_field_data {
1655 	SES_STATUS_KEY_PAD_ENTRY_IDENT_BYTE	= 0,
1656 	SES_STATUS_KEY_PAD_ENTRY_IDENT_MASK	= 0x80,
1657 	SES_STATUS_KEY_PAD_ENTRY_IDENT_SHIFT	= 7,
1658 
1659 	SES_STATUS_KEY_PAD_ENTRY_FAIL_BYTE	= 0,
1660 	SES_STATUS_KEY_PAD_ENTRY_FAIL_MASK	= 0x40,
1661 	SES_STATUS_KEY_PAD_ENTRY_FAIL_SHIFT	= 6
1662 };
1663 
1664 #define GEN_SES_STATUS_KEY_PAD_ENTRY_ACCESSORS(LCASE, UCASE)	\
1665     GEN_GETTER(ses_status_key_pad_entry, SES_STATUS_KEY_PAD_ENTRY, LCASE, UCASE)
1666 GEN_SES_STATUS_KEY_PAD_ENTRY_ACCESSORS(ident, IDENT)
1667 GEN_SES_STATUS_KEY_PAD_ENTRY_ACCESSORS(fail,  FAIL)
1668 #undef GEN_SES_STATUS_KEY_PAD_ENTRY_ACCESSORS
1669 
1670 /*------------------------- Enclosure Status Element -------------------------*/
1671 struct ses_status_enclosure {
1672 	struct ses_status_common common;
1673 	uint8_t bytes[3];
1674 };
1675 
1676 enum ses_status_enclosure_field_data {
1677 	SES_STATUS_ENCLOSURE_IDENT_BYTE					= 0,
1678 	SES_STATUS_ENCLOSURE_IDENT_MASK					= 0x80,
1679 	SES_STATUS_ENCLOSURE_IDENT_SHIFT				= 7,
1680 
1681 	SES_STATUS_ENCLOSURE_TIME_UNTIL_POWER_CYCLE_BYTE		= 1,
1682 	SES_STATUS_ENCLOSURE_TIME_UNTIL_POWER_CYCLE_MASK		= 0xFC,
1683 	SES_STATUS_ENCLOSURE_TIME_UNTIL_POWER_CYCLE_SHIFT		= 2,
1684 
1685 	SES_STATUS_ENCLOSURE_FAIL_BYTE					= 1,
1686 	SES_STATUS_ENCLOSURE_FAIL_MASK					= 0x02,
1687 	SES_STATUS_ENCLOSURE_FAIL_SHIFT					= 1,
1688 
1689 	SES_STATUS_ENCLOSURE_WARN_BYTE					= 1,
1690 	SES_STATUS_ENCLOSURE_WARN_MASK					= 0x01,
1691 	SES_STATUS_ENCLOSURE_WARN_SHIFT					= 0,
1692 
1693 	SES_STATUS_ENCLOSURE_REQUESTED_POWER_OFF_DURATION_BYTE		= 2,
1694 	SES_STATUS_ENCLOSURE_REQUESTED_POWER_OFF_DURATION_MASK		= 0xFC,
1695 	SES_STATUS_ENCLOSURE_REQUESTED_POWER_OFF_DURATION_SHIFT		= 2,
1696 	SES_STATUS_ENCLOSURE_REQUESTED_POWER_OFF_DURATION_MAX_AUTO	= 60,
1697 	SES_STATUS_ENCLOSURE_REQUESTED_POWER_OFF_DURATION_MANUAL	= 63,
1698 
1699 	SES_STATUS_ENCLOSURE_REQUESTED_FAIL_BYTE			= 2,
1700 	SES_STATUS_ENCLOSURE_REQUESTED_FAIL_MASK			= 0x02,
1701 	SES_STATUS_ENCLOSURE_REQUESTED_FAIL_SHIFT			= 1,
1702 
1703 	SES_STATUS_ENCLOSURE_REQUESTED_WARN_BYTE			= 2,
1704 	SES_STATUS_ENCLOSURE_REQUESTED_WARN_MASK			= 0x01,
1705 	SES_STATUS_ENCLOSURE_REQUESTED_WARN_SHIFT			= 0
1706 };
1707 
1708 #define GEN_SES_STATUS_ENCLOSURE_ACCESSORS(LCASE, UCASE)		\
1709     GEN_GETTER(ses_status_enclosure, SES_STATUS_ENCLOSURE, LCASE, UCASE)
1710 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(ident,          IDENT)
1711 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(time_until_power_cycle,
1712 				   TIME_UNTIL_POWER_CYCLE)
1713 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(fail,           FAIL)
1714 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(warn,           WARN)
1715 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(requested_power_off_duration,
1716 				   REQUESTED_POWER_OFF_DURATION)
1717 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(requested_fail, REQUESTED_FAIL)
1718 GEN_SES_STATUS_ENCLOSURE_ACCESSORS(requested_warn, REQUESTED_WARN)
1719 #undef GEN_SES_STATUS_ENCLOSURE_ACCESSORS
1720 
1721 /*------------------- SCSI Port/Transceiver Status Element -------------------*/
1722 struct ses_status_scsi_port_or_xcvr {
1723 	struct ses_status_common common;
1724 	uint8_t bytes[3];
1725 };
1726 
1727 enum ses_status_scsi_port_or_xcvr_field_data {
1728 	SES_STATUS_SCSI_PORT_OR_XCVR_IDENT_BYTE		= 0,
1729 	SES_STATUS_SCSI_PORT_OR_XCVR_IDENT_MASK		= 0x80,
1730 	SES_STATUS_SCSI_PORT_OR_XCVR_IDENT_SHIFT	= 7,
1731 
1732 	SES_STATUS_SCSI_PORT_OR_XCVR_FAIL_BYTE		= 0,
1733 	SES_STATUS_SCSI_PORT_OR_XCVR_FAIL_MASK		= 0x40,
1734 	SES_STATUS_SCSI_PORT_OR_XCVR_FAIL_SHIFT		= 6,
1735 
1736 	SES_STATUS_SCSI_PORT_OR_XCVR_REPORT_BYTE	= 1,
1737 	SES_STATUS_SCSI_PORT_OR_XCVR_REPORT_MASK	= 0x01,
1738 	SES_STATUS_SCSI_PORT_OR_XCVR_REPORT_SHIFT	= 0,
1739 
1740 	SES_STATUS_SCSI_PORT_OR_XCVR_DISABLED_BYTE	= 2,
1741 	SES_STATUS_SCSI_PORT_OR_XCVR_DISABLED_MASK	= 0x10,
1742 	SES_STATUS_SCSI_PORT_OR_XCVR_DISABLED_SHIFT	= 4,
1743 
1744 	SES_STATUS_SCSI_PORT_OR_XCVR_LOL_BYTE		= 2,
1745 	SES_STATUS_SCSI_PORT_OR_XCVR_LOL_MASK		= 0x02,
1746 	SES_STATUS_SCSI_PORT_OR_XCVR_LOL_SHIFT		= 1,
1747 
1748 	SES_STATUS_SCSI_PORT_OR_XCVR_XMIT_FAIL_BYTE	= 2,
1749 	SES_STATUS_SCSI_PORT_OR_XCVR_XMIT_FAIL_MASK	= 0x01,
1750 	SES_STATUS_SCSI_PORT_OR_XCVR_XMIT_FAIL_SHIFT	= 0
1751 };
1752 
1753 #define GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(LCASE, UCASE)	 \
1754     GEN_GETTER(ses_status_scsi_port_or_xcvr, SES_STATUS_SCSI_PORT_OR_XCVR,\
1755 	       LCASE, UCASE)
1756 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(ident,     IDENT)
1757 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(fail,      FAIL)
1758 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(report,    REPORT)
1759 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(disable,   DISABLED)
1760 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(lol,       LOL)
1761 GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS(xmit_fail, XMIT_FAIL)
1762 #undef GEN_SES_STATUS_SCSI_PORT_OR_XCVR_ACCESSORS
1763 
1764 /*------------------------- Language Status Element --------------------------*/
1765 struct ses_status_language {
1766 	struct ses_status_common common;
1767 	uint8_t bytes[1];
1768 	uint8_t language_code[2];
1769 };
1770 
1771 enum ses_status_language_field_data {
1772 	SES_STATUS_LANGUAGE_IDENT_BYTE	= 0,
1773 	SES_STATUS_LANGUAGE_IDENT_MASK	= 0x80,
1774 	SES_STATUS_LANGUAGE_IDENT_SHIFT	= 7
1775 };
1776 
1777 #define GEN_SES_STATUS_LANGUAGE_ACCESSORS(LCASE, UCASE)		 \
1778     GEN_GETTER(ses_status_language, SES_STATUS_LANGUAGE, LCASE, UCASE)
1779 GEN_SES_STATUS_LANGUAGE_ACCESSORS(ident, IDENT)
1780 #undef GEN_SES_STATUS_LANGUAGE_ACCESSORS
1781 
1782 /*-------------------- Communication Port Status Element ---------------------*/
1783 struct ses_status_comm_port {
1784 	struct ses_status_common common;
1785 	uint8_t bytes[3];
1786 };
1787 
1788 enum ses_status_comm_port_field_data {
1789 	SES_STATUS_COMM_PORT_IDENT_BYTE		= 0,
1790 	SES_STATUS_COMM_PORT_IDENT_MASK		= 0x80,
1791 	SES_STATUS_COMM_PORT_IDENT_SHIFT	= 7,
1792 
1793 	SES_STATUS_COMM_PORT_FAIL_BYTE		= 0,
1794 	SES_STATUS_COMM_PORT_FAIL_MASK		= 0x40,
1795 	SES_STATUS_COMM_PORT_FAIL_SHIFT		= 6,
1796 
1797 	SES_STATUS_COMM_PORT_DISABLED_BYTE	= 2,
1798 	SES_STATUS_COMM_PORT_DISABLED_MASK	= 0x01,
1799 	SES_STATUS_COMM_PORT_DISABLED_SHIFT	= 0
1800 };
1801 
1802 #define GEN_SES_STATUS_COMM_PORT_ACCESSORS(LCASE, UCASE)		 \
1803     GEN_GETTER(ses_status_comm_port, SES_STATUS_COMM_PORT, LCASE, UCASE)
1804 GEN_SES_STATUS_COMM_PORT_ACCESSORS(ident,    IDENT)
1805 GEN_SES_STATUS_COMM_PORT_ACCESSORS(fail,     FAIL)
1806 GEN_SES_STATUS_COMM_PORT_ACCESSORS(disabled, DISABLED)
1807 #undef GEN_SES_STATUS_COMM_PORT_ACCESSORS
1808 
1809 /*---------------------- Voltage Sensor Status Element -----------------------*/
1810 struct ses_status_voltage_sensor {
1811 	struct ses_status_common common;
1812 	uint8_t bytes[1];
1813 	uint8_t voltage[2];
1814 };
1815 
1816 enum ses_status_voltage_sensor_field_data {
1817 	SES_STATUS_VOLTAGE_SENSOR_IDENT_BYTE		= 0,
1818 	SES_STATUS_VOLTAGE_SENSOR_IDENT_MASK		= 0x80,
1819 	SES_STATUS_VOLTAGE_SENSOR_IDENT_SHIFT		= 7,
1820 
1821 	SES_STATUS_VOLTAGE_SENSOR_FAIL_BYTE		= 0,
1822 	SES_STATUS_VOLTAGE_SENSOR_FAIL_MASK		= 0x40,
1823 	SES_STATUS_VOLTAGE_SENSOR_FAIL_SHIFT		= 6,
1824 
1825 	SES_STATUS_VOLTAGE_SENSOR_WARN_OVER_BYTE	= 0,
1826 	SES_STATUS_VOLTAGE_SENSOR_WARN_OVER_MASK	= 0x08,
1827 	SES_STATUS_VOLTAGE_SENSOR_WARN_OVER_SHIFT	= 3,
1828 
1829 	SES_STATUS_VOLTAGE_SENSOR_WARN_UNDER_BYTE	= 0,
1830 	SES_STATUS_VOLTAGE_SENSOR_WARN_UNDER_MASK	= 0x04,
1831 	SES_STATUS_VOLTAGE_SENSOR_WARN_UNDER_SHIFT	= 2,
1832 
1833 	SES_STATUS_VOLTAGE_SENSOR_CRIT_OVER_BYTE	= 0,
1834 	SES_STATUS_VOLTAGE_SENSOR_CRIT_OVER_MASK	= 0x02,
1835 	SES_STATUS_VOLTAGE_SENSOR_CRIT_OVER_SHIFT	= 1,
1836 
1837 	SES_STATUS_VOLTAGE_SENSOR_CRIT_UNDER_BYTE	= 0,
1838 	SES_STATUS_VOLTAGE_SENSOR_CRIT_UNDER_MASK	= 0x01,
1839 	SES_STATUS_VOLTAGE_SENSOR_CRIT_UNDER_SHIFT	= 0
1840 };
1841 
1842 #define GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(LCASE, UCASE)		\
1843     GEN_GETTER(ses_status_voltage_sensor, SES_STATUS_VOLTAGE_SENSOR,	\
1844 		  LCASE, UCASE)
1845 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(ident,      IDENT)
1846 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(fail,       FAIL)
1847 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(warn_over,  WARN_OVER)
1848 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(warn_under, WARN_UNDER)
1849 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(crit_over,  CRIT_OVER)
1850 GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS(crit_under, CRIT_UNDER)
1851 #undef GEN_SES_STATUS_VOLTAGE_SENSOR_ACCESSORS
1852 
1853 /*---------------------- Current Sensor Status Element -----------------------*/
1854 struct ses_status_current_sensor {
1855 	struct ses_status_common common;
1856 	uint8_t bytes[3];
1857 };
1858 
1859 enum ses_status_current_sensor_field_data {
1860 	SES_STATUS_CURRENT_SENSOR_IDENT_BYTE		= 0,
1861 	SES_STATUS_CURRENT_SENSOR_IDENT_MASK		= 0x80,
1862 	SES_STATUS_CURRENT_SENSOR_IDENT_SHIFT		= 7,
1863 
1864 	SES_STATUS_CURRENT_SENSOR_FAIL_BYTE		= 0,
1865 	SES_STATUS_CURRENT_SENSOR_FAIL_MASK		= 0x40,
1866 	SES_STATUS_CURRENT_SENSOR_FAIL_SHIFT		= 6,
1867 
1868 	SES_STATUS_CURRENT_SENSOR_WARN_OVER_BYTE	= 0,
1869 	SES_STATUS_CURRENT_SENSOR_WARN_OVER_MASK	= 0x08,
1870 	SES_STATUS_CURRENT_SENSOR_WARN_OVER_SHIFT	= 3,
1871 
1872 	SES_STATUS_CURRENT_SENSOR_CRIT_OVER_BYTE	= 0,
1873 	SES_STATUS_CURRENT_SENSOR_CRIT_OVER_MASK	= 0x02,
1874 	SES_STATUS_CURRENT_SENSOR_CRIT_OVER_SHIFT	= 1
1875 };
1876 
1877 #define GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS(LCASE, UCASE)		\
1878     GEN_GETTER(ses_status_current_sensor, SES_STATUS_CURRENT_SENSOR,	\
1879 		  LCASE, UCASE)
1880 GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS(ident,      IDENT)
1881 GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS(fail,       FAIL)
1882 GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS(warn_over,  WARN_OVER)
1883 GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS(crit_over,  CRIT_OVER)
1884 #undef GEN_SES_STATUS_CURRENT_SENSOR_ACCESSORS
1885 
1886 /*--------------------- SCSI Target Port Status Element ----------------------*/
1887 struct ses_status_target_port {
1888 	struct ses_status_common common;
1889 	uint8_t bytes[3];
1890 };
1891 
1892 enum ses_status_scsi_target_port_field_data {
1893 	SES_STATUS_TARGET_PORT_IDENT_BYTE	= 0,
1894 	SES_STATUS_TARGET_PORT_IDENT_MASK	= 0x80,
1895 	SES_STATUS_TARGET_PORT_IDENT_SHIFT	= 7,
1896 
1897 	SES_STATUS_TARGET_PORT_FAIL_BYTE	= 0,
1898 	SES_STATUS_TARGET_PORT_FAIL_MASK	= 0x40,
1899 	SES_STATUS_TARGET_PORT_FAIL_SHIFT	= 6,
1900 
1901 	SES_STATUS_TARGET_PORT_REPORT_BYTE	= 1,
1902 	SES_STATUS_TARGET_PORT_REPORT_MASK	= 0x01,
1903 	SES_STATUS_TARGET_PORT_REPORT_SHIFT	= 0,
1904 
1905 	SES_STATUS_TARGET_PORT_ENABLED_BYTE	= 2,
1906 	SES_STATUS_TARGET_PORT_ENABLED_MASK	= 0x01,
1907 	SES_STATUS_TARGET_PORT_ENABLED_SHIFT	= 0
1908 };
1909 
1910 #define GEN_SES_STATUS_TARGET_PORT_ACCESSORS(LCASE, UCASE)	\
1911     GEN_GETTER(ses_status_target_port, SES_STATUS_TARGET_PORT, LCASE, UCASE)
1912 GEN_SES_STATUS_TARGET_PORT_ACCESSORS(ident,   IDENT)
1913 GEN_SES_STATUS_TARGET_PORT_ACCESSORS(fail,    FAIL)
1914 GEN_SES_STATUS_TARGET_PORT_ACCESSORS(report,  REPORT)
1915 GEN_SES_STATUS_TARGET_PORT_ACCESSORS(enabled, ENABLED)
1916 #undef GEN_SES_STATUS_TARGET_PORT_ACCESSORS
1917 
1918 /*-------------------- SCSI Initiator Port Status Element --------------------*/
1919 struct ses_status_initiator_port {
1920 	struct ses_status_common common;
1921 	uint8_t bytes[3];
1922 };
1923 
1924 enum ses_status_scsi_initiator_port_field_data {
1925 	SES_STATUS_INITIATOR_PORT_IDENT_BYTE	= 0,
1926 	SES_STATUS_INITIATOR_PORT_IDENT_MASK	= 0x80,
1927 	SES_STATUS_INITIATOR_PORT_IDENT_SHIFT	= 7,
1928 
1929 	SES_STATUS_INITIATOR_PORT_FAIL_BYTE	= 0,
1930 	SES_STATUS_INITIATOR_PORT_FAIL_MASK	= 0x40,
1931 	SES_STATUS_INITIATOR_PORT_FAIL_SHIFT	= 6,
1932 
1933 	SES_STATUS_INITIATOR_PORT_REPORT_BYTE	= 1,
1934 	SES_STATUS_INITIATOR_PORT_REPORT_MASK	= 0x01,
1935 	SES_STATUS_INITIATOR_PORT_REPORT_SHIFT	= 0,
1936 
1937 	SES_STATUS_INITIATOR_PORT_ENABLED_BYTE	= 2,
1938 	SES_STATUS_INITIATOR_PORT_ENABLED_MASK	= 0x01,
1939 	SES_STATUS_INITIATOR_PORT_ENABLED_SHIFT	= 0
1940 };
1941 
1942 #define GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS(LCASE, UCASE)		\
1943     GEN_GETTER(ses_status_initiator_port, SES_STATUS_INITIATOR_PORT,	\
1944 	       LCASE, UCASE)
1945 GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS(ident,   IDENT)
1946 GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS(fail,    FAIL)
1947 GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS(report,  REPORT)
1948 GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS(enabled, ENABLED)
1949 #undef GEN_SES_STATUS_INITIATOR_PORT_ACCESSORS
1950 
1951 /*-------------------- Simple Subenclosure Status Element --------------------*/
1952 struct ses_status_simple_subses {
1953 	struct ses_status_common common;
1954 	uint8_t bytes[2];
1955 	uint8_t short_enclosure_status;
1956 };
1957 
1958 enum ses_status_simple_subses_field_data {
1959 	SES_STATUS_SIMPlE_SUBSES_IDENT_BYTE	= 0,
1960 	SES_STATUS_SIMPlE_SUBSES_IDENT_MASK	= 0x80,
1961 	SES_STATUS_SIMPlE_SUBSES_IDENT_SHIFT	= 7,
1962 
1963 	SES_STATUS_SIMPlE_SUBSES_FAIL_BYTE	= 0,
1964 	SES_STATUS_SIMPlE_SUBSES_FAIL_MASK	= 0x40,
1965 	SES_STATUS_SIMPlE_SUBSES_FAIL_SHIFT	= 6
1966 };
1967 
1968 #define GEN_SES_STATUS_SIMPlE_SUBSES_ACCESSORS(LCASE, UCASE)		\
1969     GEN_GETTER(ses_status_simple_subses, SES_STATUS_SIMPlE_SUBSES,	\
1970 		  LCASE, UCASE)
1971 GEN_SES_STATUS_SIMPlE_SUBSES_ACCESSORS(ident, IDENT)
1972 GEN_SES_STATUS_SIMPlE_SUBSES_ACCESSORS(fail,  FAIL)
1973 #undef GEN_SES_STATUS_SIMPlE_SUBSES_ACCESSORS
1974 
1975 /*----------------------- SAS Expander Status Element ------------------------*/
1976 struct ses_status_sas_expander {
1977 	struct ses_status_common common;
1978 	uint8_t bytes[3];
1979 };
1980 
1981 enum ses_status_sas_expander_field_data {
1982 	SES_STATUS_SAS_EXPANDER_IDENT_BYTE	= 0,
1983 	SES_STATUS_SAS_EXPANDER_IDENT_MASK	= 0x80,
1984 	SES_STATUS_SAS_EXPANDER_IDENT_SHIFT	= 7,
1985 
1986 	SES_STATUS_SAS_EXPANDER_FAIL_BYTE	= 0,
1987 	SES_STATUS_SAS_EXPANDER_FAIL_MASK	= 0x40,
1988 	SES_STATUS_SAS_EXPANDER_FAIL_SHIFT	= 6
1989 };
1990 
1991 #define GEN_SES_STATUS_SAS_EXPANDER_ACCESSORS(LCASE, UCASE)	\
1992     GEN_GETTER(ses_status_sas_expander, SES_STATUS_SAS_EXPANDER,	LCASE, UCASE)
1993 GEN_SES_STATUS_SAS_EXPANDER_ACCESSORS(ident, IDENT)
1994 GEN_SES_STATUS_SAS_EXPANDER_ACCESSORS(fail,  FAIL)
1995 #undef GEN_SES_STATUS_SAS_EXPANDER_ACCESSORS
1996 
1997 /*----------------------- SAS Connector Status Element -----------------------*/
1998 struct ses_status_sas_connector {
1999 	struct ses_status_common common;
2000 	uint8_t bytes[3];
2001 };
2002 
2003 enum ses_status_sas_connector_field_data {
2004 	SES_STATUS_SAS_CONNECTOR_IDENT_BYTE		= 0,
2005 	SES_STATUS_SAS_CONNECTOR_IDENT_MASK		= 0x80,
2006 	SES_STATUS_SAS_CONNECTOR_IDENT_SHIFT		= 7,
2007 
2008 	SES_STATUS_SAS_CONNECTOR_TYPE_BYTE		= 0,
2009 	SES_STATUS_SAS_CONNECTOR_TYPE_MASK		= 0x7F,
2010 	SES_STATUS_SAS_CONNECTOR_TYPE_SHIFT		= 0,
2011 
2012 	SES_STATUS_SAS_CONNECTOR_PHYS_LINK_BYTE		= 1,
2013 	SES_STATUS_SAS_CONNECTOR_PHYS_LINK_MASK		= 0xFF,
2014 	SES_STATUS_SAS_CONNECTOR_PHYS_LINK_SHIFT	= 0,
2015 	SES_STATUS_SAS_CONNECTOR_PHYS_LINK_ALL		= 0xFF,
2016 
2017 	SES_STATUS_SAS_CONNECTOR_FAIL_BYTE		= 2,
2018 	SES_STATUS_SAS_CONNECTOR_FAIL_MASK		= 0x40,
2019 	SES_STATUS_SAS_CONNECTOR_FAIL_SHIFT		= 6,
2020 };
2021 
2022 #define GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS(LCASE, UCASE)		\
2023     GEN_GETTER(ses_status_sas_connector, SES_STATUS_SAS_CONNECTOR,	\
2024 		  LCASE, UCASE)
2025 GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS(ident,     IDENT)
2026 GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS(type,      TYPE)
2027 GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS(phys_link, PHYS_LINK)
2028 GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS(fail,      FAIL)
2029 #undef GEN_SES_STATUS_SAS_CONNECTOR_ACCESSORS
2030 
2031 /*------------------------- Universal Status Element -------------------------*/
2032 union ses_status_element {
2033 	struct ses_status_common            common;
2034 	struct ses_status_dev_slot          dev_slot;
2035 	struct ses_status_array_dev_slot    array_dev_slot;
2036 	struct ses_status_power_supply      power_supply;
2037 	struct ses_status_cooling           cooling;
2038 	struct ses_status_temp_sensor       temp_sensor;
2039 	struct ses_status_door_lock         door_lock;
2040 	struct ses_status_audible_alarm     audible_alarm;
2041 	struct ses_status_ecc_electronics   ecc_electronics;
2042 	struct ses_status_scc_electronics   scc_electronics;
2043 	struct ses_status_nv_cache          nv_cache;
2044 	struct ses_status_invalid_op_reason invalid_op_reason;
2045 	struct ses_status_ups               ups;
2046 	struct ses_status_display           display;
2047 	struct ses_status_key_pad_entry     key_pad_entry;
2048 	struct ses_status_scsi_port_or_xcvr scsi_port_or_xcvr;
2049 	struct ses_status_language          language;
2050 	struct ses_status_comm_port         comm_port;
2051 	struct ses_status_voltage_sensor    voltage_sensor;
2052 	struct ses_status_current_sensor    current_sensor;
2053 	struct ses_status_target_port       target_port;
2054 	struct ses_status_initiator_port    initiator_port;
2055 	struct ses_status_simple_subses     simple_subses;
2056 	struct ses_status_sas_expander      sas_expander;
2057 	struct ses_status_sas_connector     sas_connector;
2058 	uint8_t				    bytes[4];
2059 };
2060 
2061 /*
2062  * Convert element status into control as much as possible.
2063  * Some bits have different meaning in status and control,
2064  * while others have the same and should be preserved.
2065  */
2066 static inline void
2067 ses_status_to_ctrl(uint8_t type, uint8_t *bytes)
2068 {
2069 	/* Updated to SES4r5. */
2070 	static const uint8_t mask[][4] = {
2071 	    { 0x60, 0x00, 0x00, 0x00 },	/* UNSPECIFIED */
2072 	    { 0x60, 0x00, 0x4e, 0x3c },	/* DEVICE */
2073 	    { 0x60, 0xc0, 0x00, 0x60 },	/* POWER */
2074 	    { 0x60, 0xc0, 0x00, 0x60 },	/* COOLING/FAN */
2075 	    { 0x60, 0xc0, 0x00, 0x80 },	/* THERM */
2076 	    { 0x60, 0xc0, 0x00, 0x01 },	/* DOORLOCK */
2077 	    { 0x60, 0xc0, 0x00, 0x5f },	/* ALARM */
2078 	    { 0x60, 0xf0, 0x01, 0x00 },	/* ESSC */
2079 	    { 0x60, 0xc0, 0x00, 0x00 },	/* SCC */
2080 	    { 0x60, 0xc0, 0x00, 0x00 },	/* NVRAM */
2081 	    { 0x60, 0x00, 0x00, 0x00 },	/* INV_OP_REASON */
2082 	    { 0x60, 0x00, 0x00, 0xe0 },	/* UPS */
2083 	    { 0x60, 0xc0, 0xff, 0xff },	/* DISPLAY */
2084 	    { 0x60, 0xc0, 0x00, 0x00 },	/* KEYPAD */
2085 	    { 0x60, 0x80, 0x00, 0xff },	/* ENCLOSURE */
2086 	    { 0x60, 0xc0, 0x00, 0x10 },	/* SCSIXVR */
2087 	    { 0x60, 0x80, 0xff, 0xff },	/* LANGUAGE */
2088 	    { 0x60, 0xc0, 0x00, 0x01 },	/* COMPORT */
2089 	    { 0x60, 0xc0, 0x00, 0x00 },	/* VOM */
2090 	    { 0x60, 0xc0, 0x00, 0x00 },	/* AMMETER */
2091 	    { 0x60, 0xc0, 0x00, 0x01 },	/* SCSI_TGT */
2092 	    { 0x60, 0xc0, 0x00, 0x01 },	/* SCSI_INI*/
2093 	    { 0x60, 0xc0, 0x00, 0x00 },	/* SUBENC */
2094 	    { 0x60, 0xff, 0x4e, 0x3c },	/* ARRAY_DEV */
2095 	    { 0x60, 0xc0, 0x00, 0x00 },	/* SAS_EXP */
2096 	    { 0x60, 0x80, 0x00, 0x40 },	/* SAS_CONN */
2097 	};
2098 
2099 	if (type >= sizeof(mask) / sizeof(mask[0]))
2100 		type = 0;
2101 	for (int i = 0; i < 4; i++)
2102 		bytes[i] &= mask[type][i];
2103 }
2104 
2105 /*===================== SCSI SES Status Diagnostic Page =====================*/
2106 struct ses_status_page {
2107 	struct ses_page_hdr  hdr;
2108 	union ses_status_element  elements[];
2109 };
2110 
2111 enum ses_status_page_field_data {
2112 	SES_STATUS_PAGE_INVOP_MASK	= 0x10,
2113 	SES_STATUS_PAGE_INVOP_SHIFT	= 4,
2114 
2115 	SES_STATUS_PAGE_INFO_MASK	= 0x08,
2116 	SES_STATUS_PAGE_INFO_SHIFT	= 3,
2117 
2118 	SES_STATUS_PAGE_NON_CRIT_MASK	= 0x04,
2119 	SES_STATUS_PAGE_NON_CRIT_SHIFT	= 2,
2120 
2121 	SES_STATUS_PAGE_CRIT_MASK	= 0x02,
2122 	SES_STATUS_PAGE_CRIT_SHIFT	= 1,
2123 
2124 	SES_STATUS_PAGE_UNRECOV_MASK	= 0x01,
2125 	SES_STATUS_PAGE_UNRECOV_SHIFT	= 0,
2126 
2127 	SES_STATUS_PAGE_CHANGED_MASK	= SES_STATUS_PAGE_INVOP_MASK
2128 					| SES_STATUS_PAGE_INFO_MASK
2129 					| SES_STATUS_PAGE_NON_CRIT_MASK
2130 					| SES_STATUS_PAGE_CRIT_MASK
2131 					| SES_STATUS_PAGE_UNRECOV_MASK,
2132 	SES_STATUS_PAGE_CHANGED_SHIFT	= 0,
2133 };
2134 
2135 #define GEN_SES_STATUS_PAGE_ACCESSORS(LCASE, UCASE) \
2136     GEN_HDR_ACCESSORS(ses_status_page, SES_STATUS_PAGE, LCASE, UCASE)
2137 
2138 GEN_SES_STATUS_PAGE_ACCESSORS(invop,    INVOP)
2139 GEN_SES_STATUS_PAGE_ACCESSORS(info,     INFO)
2140 GEN_SES_STATUS_PAGE_ACCESSORS(non_crit, NON_CRIT)
2141 GEN_SES_STATUS_PAGE_ACCESSORS(crit,     CRIT)
2142 GEN_SES_STATUS_PAGE_ACCESSORS(unrecov,  UNRECOV)
2143 GEN_SES_STATUS_PAGE_ACCESSORS(changed,  CHANGED)
2144 #undef GEN_SES_STATUS_PAGE_ACCESSORS
2145 
2146 /*================ SCSI SES Element Descriptor Diagnostic Page ===============*/
2147 struct ses_elem_descr {
2148 	uint8_t	reserved[2];
2149 	uint8_t	length[2];
2150 	char	description[];
2151 };
2152 
2153 struct ses_elem_descr_page {
2154 	struct ses_page_hdr   hdr;
2155 	struct ses_elem_descr descrs[];
2156 };
2157 
2158 /*============ SCSI SES Additional Element Status Diagnostic Page ============*/
2159 struct ses_addl_elem_status_page {
2160 	struct ses_page_hdr   hdr;
2161 };
2162 
2163 /*====================== Legacy (Deprecated) Structures ======================*/
2164 struct ses_control_page_hdr {
2165 	uint8_t page_code;
2166 	uint8_t control_flags;
2167 	uint8_t length[2];
2168 	uint8_t gen_code[4];
2169 /* Followed by variable length array of descriptors. */
2170 };
2171 
2172 struct ses_status_page_hdr {
2173 	uint8_t page_code;
2174 	uint8_t status_flags;
2175 	uint8_t length[2];
2176 	uint8_t gen_code[4];
2177 /* Followed by variable length array of descriptors. */
2178 };
2179 
2180 /* ses_page_hdr.reserved values */
2181 /*
2182  * Enclosure Status Diagnostic Page:
2183  * uint8_t	reserved : 3,
2184  * 		invop : 1,
2185  * 		info : 1,
2186  * 		noncritical : 1,
2187  * 		critical : 1,
2188  * 		unrecov : 1;
2189  */
2190 #define	SES_ENCSTAT_UNRECOV		0x01
2191 #define	SES_ENCSTAT_CRITICAL		0x02
2192 #define	SES_ENCSTAT_NONCRITICAL		0x04
2193 #define	SES_ENCSTAT_INFO		0x08
2194 #define	SES_ENCSTAT_INVOP		0x10
2195 /* Status mask: All of the above OR'd together */
2196 #define	SES_STATUS_MASK			0x1f
2197 #define	SES_SET_STATUS_MASK		0xf
2198 /* Element Descriptor Diagnostic Page: unused */
2199 /* Additional Element Status Diagnostic Page: unused */
2200 
2201 /* Summary SES Status Defines, Common Status Codes */
2202 #define	SES_OBJSTAT_UNSUPPORTED		0
2203 #define	SES_OBJSTAT_OK			1
2204 #define	SES_OBJSTAT_CRIT		2
2205 #define	SES_OBJSTAT_NONCRIT		3
2206 #define	SES_OBJSTAT_UNRECOV		4
2207 #define	SES_OBJSTAT_NOTINSTALLED	5
2208 #define	SES_OBJSTAT_UNKNOWN		6
2209 #define	SES_OBJSTAT_NOTAVAIL		7
2210 #define	SES_OBJSTAT_NOACCESS		8
2211 
2212 /*
2213  * For control pages, cstat[0] is the same for the
2214  * enclosure and is common across all device types.
2215  *
2216  * If SESCTL_CSEL is set, then PRDFAIL, DISABLE and RSTSWAP
2217  * are checked, otherwise bits that are specific to the device
2218  * type in the other 3 bytes of cstat or checked.
2219  */
2220 #define	SESCTL_CSEL		0x80
2221 #define	SESCTL_PRDFAIL		0x40
2222 #define	SESCTL_DISABLE		0x20
2223 #define	SESCTL_RSTSWAP		0x10
2224 
2225 /* Control bits, Array Device Slot Elements, byte 1 */
2226 #define	SESCTL_RQSOK	0x80	/* RQST OK */
2227 #define	SESCTL_RQSRSV	0x40	/* RQST RSVD DEVICE */
2228 #define	SESCTL_RQSSPR	0x20	/* RQST HOT SPARE */
2229 #define	SESCTL_RQSCCH	0x10	/* RQST CONS CHECK */
2230 #define	SESCTL_RQSCRA	0x08	/* RQST IN CRIT ARRAY */
2231 #define	SESCTL_RQSFAA	0x04	/* RQST IN FAILED ARRAY */
2232 #define	SESCTL_RQSRR	0x02	/* RQST REBUI/REMAP */
2233 #define	SESCTL_RQSRRA	0x01	/* RQST R/R ABORT */
2234 /* Control bits, [Array] Device Slot Elements, byte 2 */
2235 #define	SESCTL_RQSACT	0x80	/* RQST ACTIVE */
2236 #define	SESCTL_DRVLCK	0x40	/* DO NOT REMOVE */
2237 #define	SESCTL_RQSMSN	0x10	/* RQST MISSING */
2238 #define	SESCTL_RQSINS	0x08	/* RQST INSERT */
2239 #define	SESCTL_RQSRMV	0x04	/* RQST REMOVE */
2240 #define	SESCTL_RQSID	0x02	/* RQST IDENT */
2241 /* Control bits, [Array] Device Slot Elements, byte 3 */
2242 #define	SESCTL_RQSFLT	0x20	/* RQST FAULT */
2243 #define	SESCTL_DEVOFF	0x10	/* DEVICE OFF */
2244 #define	SESCTL_ENBYPA	0x08	/* ENABLE BYP A */
2245 #define	SESCTL_ENBYPB	0x04	/* ENABLE BYP B */
2246 
2247 /* Control bits, Generic, byte 3 */
2248 #define	SESCTL_RQSTFAIL	0x40
2249 #define	SESCTL_RQSTON	0x20
2250 
2251 /*
2252  * Getting text for an object type is a little
2253  * trickier because it's string data that can
2254  * go up to 64 KBytes. Build this union and
2255  * fill the obj_id with the id of the object who's
2256  * help text you want, and if text is available,
2257  * obj_text will be filled in, null terminated.
2258  */
2259 
2260 typedef union {
2261 	unsigned int obj_id;
2262 	char obj_text[1];
2263 } ses_hlptxt;
2264 
2265 /*============================================================================*/
2266 struct ses_elm_desc_hdr {
2267 	uint8_t reserved[2];
2268 	uint8_t length[2];
2269 };
2270 
2271 /*
2272  * SES v2 r20 6.1.13 - Element Additional Status diagnostic page
2273  * Tables 26-28 (general), 29-32 (FC), 33-41 (SAS)
2274  *
2275  * Protocol identifier uses definitions in scsi_all.h;
2276  * SPSP_PROTO_FC, SPSP_PROTO_SAS are the only ones used here.
2277  */
2278 
2279 struct ses_elm_fc_eip_hdr {
2280 	uint8_t num_phys;
2281 	uint8_t reserved[2];
2282 	uint8_t dev_slot_num;
2283 	uint8_t node_name[8];
2284 };
2285 
2286 struct ses_elm_fc_noneip_hdr {
2287 	uint8_t num_phys;
2288 	uint8_t reserved;
2289 	uint8_t node_name[8];
2290 };
2291 
2292 struct ses_elm_fc_base_hdr {
2293 	uint8_t num_phys;
2294 };
2295 
2296 union ses_elm_fc_hdr {
2297 	struct ses_elm_fc_base_hdr	base_hdr;
2298 	struct ses_elm_fc_eip_hdr	eip_hdr;
2299 	struct ses_elm_fc_noneip_hdr	noneip_hdr;
2300 };
2301 
2302 struct ses_elm_fc_port {
2303 	uint8_t port_loop_position;
2304 	uint8_t bypass_reason;
2305 #define SES_FC_PORT_BYPASS_UNBYPASSED			0x00
2306 
2307 #define	SES_FC_PORT_BYPASS_LINKFAIL_RATE_TOO_HIGH	0x10
2308 #define	SES_FC_PORT_BYPASS_SYNC_LOSS_RATE_TOO_HIGH	0x11
2309 #define	SES_FC_PORT_BYPASS_SIGNAL_LOSS_RATE_TOO_HIGH	0x12
2310 #define	SES_FC_PORT_BYPASS_SEQPROTO_ERR_RATE_TOO_HIGH	0x13
2311 #define	SES_FC_PORT_BYPASS_INVAL_XMIT_RATE_TOO_HIGH	0x14
2312 #define	SES_FC_PORT_BYPASS_CRC_ERR_RATE_TOO_HIGH	0x15
2313 
2314 #define	SES_FC_PORT_BYPASS_ERR_RATE_RESERVED_BEGIN	0x16
2315 #define	SES_FC_PORT_BYPASS_ERR_RATE_RESERVED_END	0x1F
2316 
2317 #define	SES_FC_PORT_BYPASS_LINKFAIL_COUNT_TOO_HIGH	0x20
2318 #define	SES_FC_PORT_BYPASS_SYNC_LOSS_COUNT_TOO_HIGH	0x21
2319 #define	SES_FC_PORT_BYPASS_SIGNAL_LOSS_COUNT_TOO_HIGH	0x22
2320 #define	SES_FC_PORT_BYPASS_SEQPROTO_ERR_COUNT_TOO_HIGH	0x23
2321 #define	SES_FC_PORT_BYPASS_INVAL_XMIT_COUNT_TOO_HIGH	0x24
2322 #define	SES_FC_PORT_BYPASS_CRC_ERR_COUNT_TOO_HIGH	0x25
2323 
2324 #define	SES_FC_PORT_BYPASS_ERR_COUNT_RESERVED_BEGIN	0x26
2325 #define	SES_FC_PORT_BYPASS_ERR_COUNT_RESERVED_END	0x2F
2326 
2327 #define	SES_FC_PORT_BYPASS_RESERVED_BEGIN		0x30
2328 #define	SES_FC_PORT_BYPASS_RESERVED_END			0xBF
2329 
2330 #define	SES_FC_PORT_BYPASS_VENDOR_SPECIFIC_BEGIN	0xC0
2331 #define	SES_FC_PORT_BYPASS_VENDOR_SPECIFIC_END		0xFF
2332 	uint8_t port_req_hard_addr;
2333 	uint8_t n_port_id[3];
2334 	uint8_t n_port_name[8];
2335 };
2336 
2337 struct ses_elm_sas_device_phy {
2338 	uint8_t byte0;
2339 	/*
2340 	 * uint8_t reserved0 : 1,
2341 	 * uint8_t device_type : 3,
2342 	 * uint8_t reserved1 : 4;
2343 	 */
2344 
2345 	uint8_t reserved0;
2346 
2347 	/* Bit positions for initiator and target port protocols */
2348 #define	SES_SASOBJ_DEV_PHY_SMP		0x2
2349 #define	SES_SASOBJ_DEV_PHY_STP		0x4
2350 #define	SES_SASOBJ_DEV_PHY_SSP		0x8
2351 	/* Select all of the above protocols */
2352 #define	SES_SASOBJ_DEV_PHY_PROTOMASK	0xe
2353 	uint8_t initiator_ports;
2354 	/*
2355 	 * uint8_t reserved0 : 4,
2356 	 * uint8_t ssp : 1,
2357 	 * uint8_t stp : 1,
2358 	 * uint8_t smp : 1,
2359 	 * uint8_t reserved1 : 3;
2360 	 */
2361 	uint8_t target_ports;
2362 	/*
2363 	 * uint8_t sata_port_selector : 1,
2364 	 * uint8_t reserved : 3,
2365 	 * uint8_t ssp : 1,
2366 	 * uint8_t stp : 1,
2367 	 * uint8_t smp : 1,
2368 	 * uint8_t sata_device : 1;
2369 	 */
2370 	uint8_t parent_addr[8];		/* SAS address of parent */
2371 	uint8_t phy_addr[8];		/* SAS address of this phy */
2372 	uint8_t phy_id;
2373 	uint8_t reserved1[7];
2374 };
2375 #ifdef _KERNEL
2376 int ses_elm_sas_dev_phy_sata_dev(struct ses_elm_sas_device_phy *);
2377 int ses_elm_sas_dev_phy_sata_port(struct ses_elm_sas_device_phy *);
2378 int ses_elm_sas_dev_phy_dev_type(struct ses_elm_sas_device_phy *);
2379 #endif	/* _KERNEL */
2380 
2381 struct ses_elm_sas_expander_phy {
2382 	uint8_t connector_index;
2383 	uint8_t other_index;
2384 };
2385 
2386 struct ses_elm_sas_port_phy {
2387 	uint8_t phy_id;
2388 	uint8_t reserved;
2389 	uint8_t connector_index;
2390 	uint8_t other_index;
2391 	uint8_t phy_addr[8];
2392 };
2393 
2394 struct ses_elm_sas_type0_base_hdr {
2395 	uint8_t num_phys;
2396 	uint8_t byte1;
2397 	/*
2398 	 * uint8_t descriptor_type : 2,
2399 	 * uint8_t reserved : 5,
2400 	 * uint8_t not_all_phys : 1;
2401 	 */
2402 #define	SES_SASOBJ_TYPE0_NOT_ALL_PHYS(obj)	\
2403 	((obj)->byte1 & 0x1)
2404 };
2405 
2406 struct ses_elm_sas_type0_eip_hdr {
2407 	struct ses_elm_sas_type0_base_hdr base;
2408 	uint8_t reserved;
2409 	uint8_t dev_slot_num;
2410 };
2411 
2412 struct ses_elm_sas_type1_expander_hdr {
2413 	uint8_t num_phys;
2414 	uint8_t byte1;
2415 	/*
2416 	 * uint8_t descriptor_type : 2,
2417 	 * uint8_t reserved : 6;
2418 	 */
2419 	uint8_t reserved[2];
2420 	uint8_t sas_addr[8];
2421 };
2422 
2423 struct ses_elm_sas_type1_nonexpander_hdr {
2424 	uint8_t num_phys;
2425 	uint8_t byte1;
2426 	/*
2427 	 * uint8_t descriptor_type : 2,
2428 	 * uint8_t reserved : 6;
2429 	 */
2430 	uint8_t reserved[2];
2431 };
2432 
2433 /* NB: This is only usable for as long as the headers happen to match */
2434 struct ses_elm_sas_base_hdr {
2435 	uint8_t num_phys;
2436 	uint8_t byte1;
2437 	/*
2438 	 * uint8_t descriptor_type : 2,
2439 	 * uint8_t descr_specific : 6;
2440 	 */
2441 #define	SES_SASOBJ_TYPE_SLOT	0
2442 #define	SES_SASOBJ_TYPE_OTHER	1
2443 };
2444 
2445 union ses_elm_sas_hdr {
2446 	struct ses_elm_sas_base_hdr 			base_hdr;
2447 	struct ses_elm_sas_type0_base_hdr		type0_noneip;
2448 	struct ses_elm_sas_type0_eip_hdr		type0_eip;
2449 	struct ses_elm_sas_type1_expander_hdr		type1_exp;
2450 	struct ses_elm_sas_type1_nonexpander_hdr	type1_nonexp;
2451 };
2452 int ses_elm_sas_type0_not_all_phys(union ses_elm_sas_hdr *);
2453 int ses_elm_sas_descr_type(union ses_elm_sas_hdr *);
2454 
2455 /*
2456  * This structure for SPSP_PROTO_ATA is not defined by SES specs,
2457  * but purely my own design to make AHCI EM interoperate with SES.
2458  * Since no other software I know can talk to SEMB, and we do not
2459  * expose this outside, it should be safe to do what we want.
2460  */
2461 struct ses_elm_ata_hdr {
2462 	uint8_t bus[4];
2463 	uint8_t target[4];
2464 };
2465 
2466 struct ses_elm_addlstatus_base_hdr {
2467 	uint8_t byte0;
2468 	/*
2469 	 * uint8_t invalid : 1,
2470 	 * uint8_t reserved : 2,
2471 	 * uint8_t eip : 1,
2472 	 * uint8_t proto_id : 4;
2473 	 */
2474 	uint8_t length;
2475 };
2476 int ses_elm_addlstatus_proto(struct ses_elm_addlstatus_base_hdr *);
2477 int ses_elm_addlstatus_eip(struct ses_elm_addlstatus_base_hdr *);
2478 int ses_elm_addlstatus_invalid(struct ses_elm_addlstatus_base_hdr *);
2479 
2480 struct ses_elm_addlstatus_eip_hdr {
2481 	struct ses_elm_addlstatus_base_hdr base;
2482 	uint8_t byte2;
2483 #define	SES_ADDL_EIP_EIIOE_MASK	3
2484 #define	SES_ADDL_EIP_EIIOE_SES2	0
2485 #define	SES_ADDL_EIP_EIIOE_GLOB	1
2486 #define	SES_ADDL_EIP_EIIOE_IND	2
2487 #define	SES_ADDL_EIP_EIIOE_MIX	3
2488 #define	SES_ADDL_EIP_EIIOE_EI_GLOB(x)				\
2489     (((x) & SES_ADDL_EIP_EIIOE_MASK) == SES_ADDL_EIP_EIIOE_GLOB)
2490 	uint8_t element_index;
2491 	/* NB: This define (currently) applies to all eip=1 headers */
2492 #define	SES_EIP_HDR_EXTRA_LEN	2
2493 };
2494 
2495 union ses_elm_addlstatus_descr_hdr {
2496 	struct ses_elm_addlstatus_base_hdr	base;
2497 	struct ses_elm_addlstatus_eip_hdr	eip;
2498 };
2499 
2500 union ses_elm_addlstatus_proto_hdr {
2501 	union ses_elm_fc_hdr	fc;
2502 	union ses_elm_sas_hdr	sas;
2503 };
2504 
2505 /*============================= Namespace Cleanup ============================*/
2506 #undef GEN_HDR_ACCESSORS
2507 #undef GEN_ACCESSORS
2508 #undef GEN_HDR_SETTER
2509 #undef GEN_HDR_GETTER
2510 #undef GEN_SETTER
2511 #undef GEN_GETTER
2512 #undef MK_ENUM
2513 
2514 #endif	/* _SCSI_SES_H_ */
2515