xref: /titanic_50/usr/src/uts/sun4u/montecarlo/sys/scsb_led.h (revision 03831d35f7499c87d51205817c93e9a8d42c4bae)
1*03831d35Sstevel /*
2*03831d35Sstevel  * CDDL HEADER START
3*03831d35Sstevel  *
4*03831d35Sstevel  * The contents of this file are subject to the terms of the
5*03831d35Sstevel  * Common Development and Distribution License (the "License").
6*03831d35Sstevel  * You may not use this file except in compliance with the License.
7*03831d35Sstevel  *
8*03831d35Sstevel  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*03831d35Sstevel  * or http://www.opensolaris.org/os/licensing.
10*03831d35Sstevel  * See the License for the specific language governing permissions
11*03831d35Sstevel  * and limitations under the License.
12*03831d35Sstevel  *
13*03831d35Sstevel  * When distributing Covered Code, include this CDDL HEADER in each
14*03831d35Sstevel  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*03831d35Sstevel  * If applicable, add the following below this CDDL HEADER, with the
16*03831d35Sstevel  * fields enclosed by brackets "[]" replaced with your own identifying
17*03831d35Sstevel  * information: Portions Copyright [yyyy] [name of copyright owner]
18*03831d35Sstevel  *
19*03831d35Sstevel  * CDDL HEADER END
20*03831d35Sstevel  */
21*03831d35Sstevel 
22*03831d35Sstevel /*
23*03831d35Sstevel  * Copyright 2000 Sun Microsystems, Inc.  All rights reserved.
24*03831d35Sstevel  * Use is subject to license terms.
25*03831d35Sstevel  */
26*03831d35Sstevel 
27*03831d35Sstevel /*
28*03831d35Sstevel  * Netra ct SCB/SSB driver (scsb) support for controlling the
29*03831d35Sstevel  * LEDs on the System Status Board that represent the cPCI Slots.
30*03831d35Sstevel  * Each slot has a pair of LEDs, one green (OK) and one amber (NOK).
31*03831d35Sstevel  * The OK (green) LED can also be made to blink.
32*03831d35Sstevel  */
33*03831d35Sstevel 
34*03831d35Sstevel #ifndef	_SYS_SCSB_LED_H
35*03831d35Sstevel #define	_SYS_SCSB_LED_H
36*03831d35Sstevel 
37*03831d35Sstevel #pragma ident	"%Z%%M%	%I%	%E% SMI"
38*03831d35Sstevel 
39*03831d35Sstevel #ifdef	__cplusplus
40*03831d35Sstevel extern "C" {
41*03831d35Sstevel #endif
42*03831d35Sstevel 
43*03831d35Sstevel #define	_SCSBIOC		('s' << 8)
44*03831d35Sstevel 
45*03831d35Sstevel /* The ioctl command */
46*03831d35Sstevel #define	ENVC_IOC_SETFSP		(_SCSBIOC | 23)
47*03831d35Sstevel 
48*03831d35Sstevel /* Netra ct 400 has 5 slots, Netra ct 800 has 8 slots.  Including CPU */
49*03831d35Sstevel #define	NCT800_MAX_SLOTS	8
50*03831d35Sstevel #define	NCT400_MAX_SLOTS	5
51*03831d35Sstevel 
52*03831d35Sstevel typedef	uint16_t	scsb_unum_t;
53*03831d35Sstevel 
54*03831d35Sstevel typedef enum {
55*03831d35Sstevel 	SLOT	= 0
56*03831d35Sstevel } scsb_utype_t;
57*03831d35Sstevel 
58*03831d35Sstevel typedef enum {
59*03831d35Sstevel 	NOK =	0,
60*03831d35Sstevel 	OK  =	1,
61*03831d35Sstevel } scsb_led_t;
62*03831d35Sstevel 
63*03831d35Sstevel typedef enum {
64*03831d35Sstevel 	OFF =	0,
65*03831d35Sstevel 	ON  =	1,
66*03831d35Sstevel 	BLINK =	2
67*03831d35Sstevel } scsb_ustate_t;
68*03831d35Sstevel 
69*03831d35Sstevel typedef struct {
70*03831d35Sstevel 	scsb_unum_t	unit_number;
71*03831d35Sstevel 	scsb_utype_t	unit_type;
72*03831d35Sstevel 	scsb_ustate_t	unit_state;
73*03831d35Sstevel 	scsb_led_t	led_type;
74*03831d35Sstevel } scsb_uinfo_t;
75*03831d35Sstevel 
76*03831d35Sstevel #ifdef	__cplusplus
77*03831d35Sstevel }
78*03831d35Sstevel #endif
79*03831d35Sstevel 
80*03831d35Sstevel #endif	/* _SYS_SCSB_LED_H */
81